当前位置: 首页 > news >正文

从lettcue插件看skywalking

lettcue 的写操作是异步的。io.lettuce.core.RedisChannelWriter.write进行写入,io.lettuce.core.protocol.RedisCommand进行异步读取数据

skywalking 插件大体逻辑

  • 在方法执行前,通过ContextManager创建span
  • 创建span的同时,判断trace上下文是否存在,不存在则创建
  • 创建AbstractTracerContext的同时,会创建TraceSegment,创建TraceSegment的同时会创建trace id
  • 方法执行完后ContextManager.stopSpan()记录结束时间,以及将TraceSegment数据发到发送队列,准备发送到服务端

异步操作

  • 异步开始执行span.prepareForAsync();
  • 异步结束执行span.asyncFinish ();设置结束时间

trace概念:
每个完整请求是一个trace,skywalking中还有个segment的概念,代表每个线程的trace。每个segment下有多个span,代表具体的方法操作,span分为exit span(调用外部,例如:rpc db)、entry span(入口span,比如http 入口)、local span(本地的业务方法)

RedisChannelWriterInterceptor

io.lettuce.core.RedisChannelWriter.write 的拦截器代码截图。
在这里插入图片描述

ContextManager.createExitSpan
创建span ,如果没有创建过trace上下文,则创建,有则获取。
在这里插入图片描述
在这里插入图片描述
创建trace 上下文
在这里插入图片描述
在这里插入图片描述
每个线程创建一个新的segment
在这里插入图片描述
GlobalIdGenerator.generate(); 用以生成唯一的trace id或segment id
在这里插入图片描述
在这里插入图片描述

RedisCommandCompleteMethodInterceptor

io.lettuce.core.protocol.RedisCommand

在这里插入图片描述
AbstractTracingSpan.asyncFinish 异步完成
在这里插入图片描述

http://www.lryc.cn/news/8152.html

相关文章:

  • explain 每个列的含义
  • 网络通信编程基础
  • Linux网络编程
  • ***httpGet,httpPost,postman_http,httpClientSocket,httpSocketServer***
  • Downie4.6.7
  • 重构是什么
  • (考研湖科大教书匠计算机网络)第四章网络层-第六节1:路由选择协议概述
  • vue2源码之生命周期篇
  • 从零实现WebRTC(三):WebRTC中重要的API
  • shell脚本的编写以及shell中语句(嵌入式学习)
  • 2023年高新技术企业怎么申报认定
  • GIS状态检测新技术——振动分析法
  • Python进阶篇(一)-- Django快速上手
  • 读书笔记//来自公众号(1)
  • 10款让程序员用了会上瘾的工具
  • 类和对象(下)(一)
  • 46.在ROS中实现global planner(2)
  • 05- 泰坦尼克号海难生死预测 (机器学习集成算法) (项目五)
  • 【python百炼成魔】python运算符的使用与输入输出函数
  • uniapp实现app检查更新与升级-uni-upgrade-center详解
  • 公司项目引入这种方式,开发应用真是又快又准!
  • virtuoso数据库介绍
  • linux高级命令之编辑器 vim
  • 分布式光伏储能系统的优化配置方法(Matlab代码实现)
  • Grafana loki部署及使用及问题处理方法(超详细)
  • vue项目如何使用 SheetJS(xlsx)插件?
  • 项目管理工具dhtmlxGantt甘特图入门教程(九):支持哪些数据格式(上篇)
  • iView Table合并单元格(行、列)
  • 如何用P6软件编制项目进度计划(下)
  • 环境配置完整指导——Installing C++ Distributions of PyTorch