实现.Net程序中OpenTracing采样和上报配置的自动更新
前言
OpenTracing是一個鏈路跟蹤的開放協議,已經有開源的.net實現:opentracing-csharp,同時支持.net framework和.net core,Github地址:https://github.com/opentracing/opentracing-csharp。
這個庫支持多種鏈路跟蹤模式,不過僅提供了最基礎的功能,想用在實際項目中還需要做很多增強,還好也有人做了開源項目:opentracing-contrib,Github地址:https://github.com/opentracing-contrib/csharp-netcore。
opentracing-contrib中集成了一個名為Jaeger的類庫,這個庫實現了鏈路跟蹤數據的采樣和上報,支持將數據上傳到Jaeger進行分析統計。
為了同時保障性能和跟蹤關鍵數據,能夠遠程調整采樣率是很重要的,Jaeger本身也提供了遠程配置采樣率的支持。
不過我這里用的阿里云鏈路跟蹤不支持,配置的設計也和想要的不同,所以自己做了一個采樣和上報配置的動態更新,也才有了這篇文章。
思路
使用Jaeger初始化Tracer大概是這樣的:
var tracer = new Tracer.Builder(serviceName).WithSampler(sampler).WithReporter(reporter).Build(); GlobalTracer.Register(tracer);首先是提供當前服務的名字,然后需要提供一個采樣器,再提供一個上報器,Build下生成ITracer的一個實例,最后注冊到全局。
可以分析得出,采樣和上報配置的更新就是更新采樣器和上報器。
不過Tracer并沒有提供UpdateSampler和UdapteReporter的方法,被卡住了,怎么辦呢?
前文提到Jaeger是支持采樣率的動態調整的,看看它怎么做的:
這里只留下關鍵代碼,可以看到核心就是:通過一個Timer定時獲取采樣策略,然后替換原來的Sampler。
這是一個很好理解的辦法,下邊就按照這個思路來搞。
方案
分別提供一個可更新的Sampler和可更新的Reporter,Build Tracer時使用這兩個可更新的類。這里延續開源項目中Samper和Reporter的創建方式,給出這兩個類。
可更新的Sampler:
可更新的Reporter:
注意這里邊用到了讀寫鎖,因為要做到不停止服務的更新,而且大部分情況下都是讀,使用lock就有點大柴小用了。
現在初始化Tracer大概是這樣的:
當配置發生改變時,調用sampler和reporter的更新方法:
這里就不寫如何監聽配置的改變了,使用Timer或者阻塞查詢等等都可以。
后記
opentracing-contrib這個項目只支持.net core,如果想用在.net framwork中還需要自己搞,這個方法會單獨寫一篇文章,這里就不做介紹了。
總結
以上是生活随笔為你收集整理的实现.Net程序中OpenTracing采样和上报配置的自动更新的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 15分钟从零开始搭建支持10w+用户的生
 - 下一篇: 15分钟从零开始搭建支持10w+用户的生