spring-cloud-sleuth

sleuth输出的日志格式

1
2019-04-29 16:37:54.849  INFO [sleuth,fd6f9ebb8f69ab75,fd6f9ebb8f69ab75,false] 1616 --- [ctor-http-nio-2] t.y.sc.sleuth.service.UserServiceImpl    : list: [{id=1, name=test_1}, {id=2, name=test_2}, {id=3, name=test_3}, {id=4, name=test_4}, {id=5, name=test_5}, {id=6, name=test_6}, {id=7, name=test_7}, {id=8, name=test_8}, {id=9, name=test_9}, {id=10, name=test_10}]

可以看到内容是由[appname,traceId,spanId,exportable]组成的, 具体含义如下:

  • appname:服务的名称,也就是spring.application.name的值
  • traceId:整个请求的唯一ID,它标识整个整个请求的链路
  • spanId:基本的工作单元,发起一起远程调用就是一个span
  • exportable:是否导入数据到Zipkin中

sleuth的数据推送到logstash

将跟踪的信息导入到ES中,可以将跟踪的信息以JSON格式的数据输出到 logstash,再输出到ES中

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<springProperty scope="context" name="appName" source="spring.application.name"/>

<!-- Appender to log to file in a JSON format -->
<appender name="logstash" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_FILE}.json</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_FILE}.json.%d{yyyy-MM-dd}.gz</fileNamePattern>
<maxHistory>7</maxHistory>
</rollingPolicy>
<encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
<providers>
<timestamp>
<timeZone>UTC</timeZone>
</timestamp>
<pattern>
<pattern>
{
"level": "%level",
"appName": "${appName:-}",
"traceId": "%X{X-B3-TraceId:-}",
"spanId": "%X{X-B3-SpanId:-}",
"parentId": "%X{X-B3-ParentSpanId:-}",
"exportable": "%X{X-Span-Export:-}",
"pid": "${PID:-}",
"thread": "%thread",
"class": "%logger{40}",
"msg": "%message"
}
</pattern>
</pattern>
</providers>
</encoder>
</appender>
  • 本文作者: forever杨
  • 本文链接: https://blog.yl-online.top/posts/ccd87ced.html
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。如果文章内容对你有用,请记录到你的笔记中。本博客站点随时会停止服务,请不要收藏、转载!