歡迎訪問我的GitHub
https://github.com/zq2599/blog_demos
內容:所有原創文章分類匯總及配套原始碼,涉及Java、Docker、Kubernetes、DevOPS等;
《Jaeger實戰(Java版)》系列全文
- 《分布式呼叫鏈跟蹤工具Jaeger?兩分鐘極速體驗》
- 《Jaeger開發入門(java版)》
- 《Java應用日志如何與Jaeger的trace關聯》
- 《Jaeger的客戶端采樣配置》
- 《極簡!一個注解就能創建Jaeger的Span》
- 《Jaeger知識點補充》
本篇概覽
- 本文是《Jaeger實戰(Java版)》系列的終篇,一同學習和實戰是一段愉快的時光,如今終于到了說再見的時候,最后將平時積累的三個有用的知識點奉上,既作為結尾,也希望能為您的開發帶來幫助:
- 修改服務名
- 關閉span上報的日志
- all-in-one鏡像的持久化存盤
修改服務名
- 在Jaeger的web頁面上看到的服務名,默認用的是spring.application.name配置的值,如果您不滿意,可以自行定制,配置項是opentracing.jaeger.service-name,如下圖紅框所示,我這里改成了中文名:

- 運行起來后,在Jaeger的web頁面展示如下圖紅框:

關閉span上報的日志
- 以下是一段日志,只有前面兩行是咱們寫代碼的時候用log.info方法列印出來的,剩下的四行都是Jaeger SDK輸出的
00:18:12 [http-nio-8080-exec-1] INFO c.b.j.p.c.HelloController [traceId=49476da841cd354b spanId=b595271a496cb0cb sampled=true] start hello from [1632269892342]
00:18:12 [http-nio-8080-exec-1] INFO c.b.j.p.c.HelloController [traceId=49476da841cd354b spanId=b595271a496cb0cb sampled=true] hello
00:18:12 [http-nio-8080-exec-1] INFO i.j.i.r.LoggingReporter [traceId=49476da841cd354b spanId=b595271a496cb0cb sampled=true] Span reported: 49476da841cd354b:991b82965543f8da:e6333b3a1c14f544:1 - mockBizChild
00:18:12 [http-nio-8080-exec-1] INFO i.j.i.r.LoggingReporter [traceId=49476da841cd354b spanId=b595271a496cb0cb sampled=true] Span reported: 49476da841cd354b:e6333b3a1c14f544:b595271a496cb0cb:1 - mockBiz
00:18:13 [http-nio-8080-exec-1] INFO i.j.i.r.LoggingReporter [traceId=49476da841cd354b spanId=b595271a496cb0cb sampled=true] Span reported: 49476da841cd354b:45e256ba3deed679:b595271a496cb0cb:1 - SET
00:18:13 [http-nio-8080-exec-1] INFO i.j.i.r.LoggingReporter [traceId= spanId= sampled=] Span reported: 49476da841cd354b:b595271a496cb0cb:6322077c0edb62cc:1 - hello
- 上述日志中,Jaeger SDK輸出的那些內容,一般情況下用處不大,可以用以下紅框中的配置關閉掉:

- 再次運行,日志如下,清凈了:
00:12:42 [http-nio-8080-exec-10] INFO c.b.j.p.c.HelloController [traceId=6430f498d5623103 spanId=9e4a4c8bb326352b sampled=true] start hello from [1632269562868]
00:12:42 [http-nio-8080-exec-10] INFO c.b.j.p.c.HelloController [traceId=6430f498d5623103 spanId=9e4a4c8bb326352b sampled=true] hello
all-in-one鏡像的持久化存盤
- 用all-in-one鏡像部署Jaeger服務端,特點是簡單快捷,適合在開發和除錯階段使用,下面一個命令即可完成部署:
docker run -d \
--name jaeger \
-e COLLECTOR_ZIPKIN_HTTP_PORT=9411 \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 14269:14269 \
-p 9411:9411 jaegertracing/all-in-one:1.26
- 上述命令雖然能讓Jaeger后端正常作業,但有個缺陷:資料保存在記憶體中,容器重啟后資料不可恢復,為了解決這個問題,可以在all-in-one鏡像的容器上開啟badger(一種嵌入式存盤),并且將badger的資料存盤在宿主機上,完整的命令如下所示,其中/Users/will/temp/202109/28/data是我的電腦的磁盤目錄,請您按照自己實際情況修改:
docker run -d \
--name jaeger \
-e COLLECTOR_ZIPKIN_HTTP_PORT=9411 \
-e SPAN_STORAGE_TYPE=badger \
-e BADGER_EPHEMERAL=false \
-e BADGER_DIRECTORY_VALUE=/badger/data \
-e BADGER_DIRECTORY_KEY=/badger/key \
-v /Users/will/temp/202109/28/data:/badger \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 14269:14269 \
-p 9411:9411 jaegertracing/all-in-one:1.26
-
此時再重啟或者重建Jaeger容器,歷史資料都會完整保存
-
如果您是在docker-compose.yml中配置all-in-one鏡像,那么要注意yml檔案中無法輸入布爾型屬性值,需要參考以下方式處理:
-
首先在docker-compose.yml所在目錄創建檔案.env,內容如下:
BADGER_FLAG=true
- 最后在docker-compose.yml中,Jaeger容器的配置如下,使用了.env檔案中的配置項,另外,我這里的本地存盤用的是新建的volumes,您可以根據自己的需要改成前面那種本地磁盤映射:
version: '3.0'
networks:
jaeger-tutorials-net:
driver: bridge
ipam:
config:
- subnet: 192.168.1.0/24
gateway: 192.168.1.1
volumes:
# 用于存盤badger的資料
badger-data:
services:
jaeger:
image: jaegertracing/all-in-one:1.26
container_name: jaeger
# 處理時鐘漂移帶來的計算出負數的問題
command: ["--query.max-clock-skew-adjustment=100ms"]
# 選擇網路
networks:
- jaeger-tutorials-net
# 持久化,請選擇適合自己的目錄
environment:
SPAN_STORAGE_TYPE: badger
BADGER_EPHEMERAL: ${BADGER_FLAG}
BADGER_DIRECTORY_VALUE: /badger/data
BADGER_DIRECTORY_KEY: /badger/key
# badger存盤在本地卷(或者映射到本地某個目錄)
volumes:
- badger-data:/badger
#選擇埠
ports:
- 16686:16686/tcp
restart: always
- 至此,《Jaeger實戰(Java版)》系列終于到了說再見的時候,希望能夠為您的系統建設提供有用的參考,咱們繼續相約在下一個欣宸原創系列吧
你不孤單,欣宸原創一路相伴
- Java系列
- Spring系列
- Docker系列
- kubernetes系列
- 資料庫+中間件系列
- DevOps系列
歡迎關注公眾號:程式員欣宸
微信搜索「程式員欣宸」,我是欣宸,期待與您一同暢游Java世界...
https://github.com/zq2599/blog_demos
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/390544.html
標籤:Java
下一篇:Jaeger知識點補充
