NCC CAP 6.0 发布 —— 新增支持 OpenTelemetry
前言
今天,我們很高興宣布 CAP 發(fā)布 6.0 版本正式版,在這個(gè)版本中,我們主要致力于對(duì) OpenTelemetry 提供支持,以及更好的適配 .NET 6。
那么,接下來我們具體看一下吧。
總覽
可能有些人還不知道 CAP 是什么,老規(guī)矩來一個(gè)簡(jiǎn)介。
CAP 是一個(gè)用來解決微服務(wù)或者分布式系統(tǒng)中分布式事務(wù)問題的一個(gè)開源項(xiàng)目解決方案(https://github.com/dotnetcore/CAP)同樣可以用來作為 EventBus 使用,該項(xiàng)目誕生于2016年,目前在 Github 已經(jīng)有超過 5000+ Star 和 70 個(gè)貢獻(xiàn)者,以及在 NuGet 超200萬的下載量,并在越來越多公司的和項(xiàng)目中得到應(yīng)用。
如果你想對(duì) CAP 更多了解,請(qǐng)查看我們的 官方文檔(http://cap.dotnetcore.xyz/)。
本次在 CAP 6.0 版本中我們主要帶來了以下新特性:
適配 .NET 6 啟用 #nullable
支持 OpenTelemetry
改進(jìn) NATS Jetstream 對(duì)通配符的支持
Azure ServiceBus 支持自定義 Header
更新依賴的 NuGet 包到最新版本
適配 .NET 6
雖然上一個(gè)版本也能夠在 .NET 6 的項(xiàng)目中使用,但是在這個(gè)版本中我們升級(jí)了我們的 NuGet 包到和框架符合的 .NET 6 的版本,并且對(duì)于依賴了EF的包兼容了 .NET Standard 2.1 的支持。
過去我們使用 Jetbrains.Annotations 包對(duì)可能存在null的場(chǎng)景進(jìn)行檢查,但是并不徹底,而且IDE對(duì)其支持有限。在新的 .NET 6版本中官方已經(jīng)默認(rèn)開啟了#nullable的功能,所以我們也是將所有的庫都進(jìn)行了啟用,以便于對(duì)可能存在null的場(chǎng)景盡可能在編譯階段知道,從而讓代碼更加穩(wěn)健。
支持 OpenTelemetry
自 2.6 版本一直以來,我們提供了對(duì) Diagnostics 的支持,并且我們?cè)?SkyAPM.Diagnostics.CAP 中提供了對(duì) Skywalking 的支持以用于做分布式跟蹤,但這僅限于在 Skywalking 中才能使用。
在 .NET 6 中,.NET 團(tuán)隊(duì)改進(jìn)了對(duì)分布式跟蹤的支持,所以在這個(gè)版本中,CAP 提供了對(duì) OpenTelemetry 的支持。
OpenTelemetry 是 CNCF 的一個(gè)可觀測(cè)性項(xiàng)目,旨在提供可觀測(cè)性領(lǐng)域的標(biāo)準(zhǔn)化方案,解決觀測(cè)數(shù)據(jù)的數(shù)據(jù)模型、采集、處理、導(dǎo)出等的標(biāo)準(zhǔn)化問題,提供與三方 vendor 無關(guān)的服務(wù)。它是一組標(biāo)準(zhǔn)和工具的集合,旨在管理觀測(cè)類數(shù)據(jù),如 trace、metrics、logs 等。
集成CAP的方式也很簡(jiǎn)單,以在 ASP.NET Core 項(xiàng)目中為例:
首先,引用 DotNetCore.CAP.OpenTelemetry 包
PM> Install-Package DotNetCore.CAP.OpenTelemetry然后,在集成了 OpenTelemetry 的項(xiàng)目( https://opentelemetry.io/docs/instrumentation/net/getting-started/#aspnet-core )中添加 CAP 的 Instrumentation 即可。
public?void?ConfigureServices(IServiceCollection?services){services.AddOpenTelemetryTracing((builder)?=>?builder.AddAspNetCoreInstrumentation().AddCapInstrumentation()?// <-- CAP 的支持,只需添加此行.AddZipkinExporter());}這樣,你就可能使用你喜愛的工具來對(duì)跟蹤請(qǐng)求進(jìn)行查看。以下為CAP 在 Zipkin 的一個(gè)截圖。
你可以在文檔中找到更多信息。
https://cap.dotnetcore.xyz/user-guide/zh/monitoring/opentelemetry/
改進(jìn) NATS Jetstream 對(duì)通配符的支持
我們?cè)谏蟼€(gè)版本(5.2)中改進(jìn)了對(duì) JetStream 的支持,但是不能發(fā)送帶有* 通配符的消息,這個(gè)在 JetStream中是受支持的,在這個(gè)版本中我們對(duì)此進(jìn)行了優(yōu)化,現(xiàn)在你可能正常的發(fā)送帶有通配符的消息。
此外,我們還提供了 NormalizeStreamName 配置項(xiàng)用于處于多個(gè)不同名稱的流綁定同一個(gè)Topic的問題,默認(rèn)情況下使用 '.' 前面的字符認(rèn)為處于一個(gè)組。
Azure ServiceBus 支持自定義 Header
在這個(gè)版本中,Azure ServiceBus 也提供了 CustomHeaders 配置項(xiàng)用于接收來自于異構(gòu)系統(tǒng)中發(fā)送的消息。你可以在文檔中找到更多信息。
https://cap.dotnetcore.xyz/user-guide/en/transport/azure-service-bus/#heterogeneous-systems
感謝 @mviegas 對(duì)此提交的PR。
其他
其他的一些改進(jìn)項(xiàng)目包括:
1、我們將所有的 nuget 的依賴包都升級(jí)到了最新版本。
2、修復(fù)了一些已知的Bug,你可以在 Github Release 中看到。
總結(jié)
以上,就是本版本中支持的一些新特性,感謝大家的支持,我們很開心能夠幫助到大家 。大家在使用的過程中遇到問題希望也能夠積極的反饋,幫助CAP變得越來越好。😃
總結(jié)
以上是生活随笔為你收集整理的NCC CAP 6.0 发布 —— 新增支持 OpenTelemetry的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Beetlex官网迁移完成
- 下一篇: git代码提交流程