日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

实现.Net程序中OpenTracing采样和上报配置的自动更新

發布時間:2023/12/4 asp.net 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 实现.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采样和上报配置的自动更新的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。