SkyWalking之P0核心业务场景输出调用链路应用

延伸扩展:XX核心业务场景

路由标签打标、传播、检索

链路标签染色与传播

SW: SkyWalking的简写

  1. 用户请求携带HTTP头信息X-sw8-correlation
    • "X-sw8-correlation: key1=value1,key2=value2,key3=value3"
  2. 网关侧读取解析HTTP头信息X-sw8-correlation,然后通过SW的关联上下文传播
    • ContextManager.getCorrelationContext().put(key, value)
      • SW插件使用
    • TraceContext.putCorrelation(key, value)
      • 应用使用
  3. 上游业务应用通过SW的关联上下文传播路由标签
    • CorrelationContext
  • 业务应用通过JVM启动参数属性 设置SW关联上下文的Span跨度标签 键的集合java -Dskywalking.correlation.auto_tag_keys=autotag1,autotag2,进行自动打标搜索。
  • 业务应用通过环境变量 设置SW关联上下文的Span跨度标签键的集合SW_CORRELATION_AUTO_TAG_KEYS=autotag1,autotag2,进行自动打标搜索。

应用变更

  • apm-gateway-trace-plugin,SW插件,feature/guangyi/20240531_span_tag_sw8_correlation分支
    • 网关应用java代理
  • 链路标签染色与传播

使用示例

链路标签数据检索

{"query":"query queryTraces (condition: TraceQueryCondition) {\n data: queryBasicTraces(condition: condition) {\n traces {\n key: segmentId\n endpointNames\n duration\n start\n isError\n traceIds\n }\n }}","variables":{"condition":{"queryDuration ":{"start":"2024-06-03 0624","end":"2024-06-03 0654","step":"MINUTE"},"traceState ":"ALL","queryOrder":"BY_START_TIME","paging":{"pageNum":1,"pageSize":20},"tags":[{"key":"http.status_code","value":"200"}],"minTraceDuration":null,"maxTraceDuration":null,"serviceId":"bGVmaXQtdXNlcnx8cHJvZA==.1","serviceInstanceId":"bGVmaXQtdXNlcnx8cHJvZA==.1_YmRiZGU2MTMyM2NmNGVmMDhmNDYyNzQxOWY1MDg1ZDNAMTkyLjE2OC4xMDcuMjA4"}}}

参考

相关推荐
import_random12 分钟前
[python]Flask(介绍+应用)
后端
chanalbert28 分钟前
SpringBoot设计基石:约定优于配置与模块化架构
spring boot·spring·spring cloud
林太白30 分钟前
Rust项目搭建
前端·后端·rust
江小北38 分钟前
今天去面试了,遇到一个面试题,spring单例bean是线程安全的吗?
java·后端·spring
天天摸鱼的java工程师38 分钟前
设计一个多租户 SaaS 系统,如何实现租户数据隔离(数据库级别 / 表级别)与资源配额控制?
java·后端·面试
用户67570498850240 分钟前
Go语言切片,使用技巧与避坑指南
后端
Nero1843 分钟前
代码随想录二刷第三天 | 203.移除链表元素、707.设计链表、206.反转链表
后端
木西43 分钟前
Nest.js实战:构建聊天室的群聊与私聊模块
前端·后端·nestjs
数字人直播1 小时前
跨境电商如何选择高转化率的AI数字人直播平台?
前端·后端
倚栏听风雨1 小时前
SwingUtilities.invokeAndWait()详解
后端