Pulsar.Client
2.14.0
See the version list below for details.
dotnet add package Pulsar.Client --version 2.14.0
NuGet\Install-Package Pulsar.Client -Version 2.14.0
<PackageReference Include="Pulsar.Client" Version="2.14.0" />
paket add Pulsar.Client --version 2.14.0
#r "nuget: Pulsar.Client, 2.14.0"
// Install Pulsar.Client as a Cake Addin #addin nuget:?package=Pulsar.Client&version=2.14.0 // Install Pulsar.Client as a Cake Tool #tool nuget:?package=Pulsar.Client&version=2.14.0
pulsar-client-dotnet
Contributions and stars ★ are most welcome!
Pulsar.Client nuget | Pulsar.Client.Otel nuget
Supported pulsar cluster versions: 2.4+
Find examples of usage in /examples folder. We are trying to keep api similar to the Java client, so please take a look at it's documentation to understand possible options available. You can also join telegram chat https://t.me/pro_pulsar for further discussions.
Features list (based on Client Feature Matrix):
- Basic Producer/Consumer API
- Partitioned topics
- Batching
- Chunking
- Compression
- TLS
- Authentication (token, tls, oauth2)
- Reader API
- Proxy Support
- Effectively-Once
- Schema (All types, Multi-version)
- Consumer seek
- Multi-topics consumer
- Topics regex consumer
- Compacted topics
- User defined properties
- Reader hasMessageAvailable
- Hostname verification
- Multi Hosts Service Url
- Key_shared subscription
- Key based batcher
- Negative Acknowledge
- Delayed/scheduled messages
- Dead Letter Policy
- Interceptors
- Transactions
- Statistics
- End-to-end Encryption
- SubscriptionInitialPosition
- Cumulative Ack
- Batch-Index Ack
- SNI Routing
- Table view
Quick contributing guide
Common steps before building
- Fork and clone locally
- Install dotnet tools:
dotnet tool restore
- Restore packages:
dotnet restore
MacOS steps before building:
- Install Snappy:
brew install snappy
- Install Libzstd:
brew install zstd
Ubuntu steps before building:
- Install Snappy:
sudo apt-get install -y libsnappy-dev
- Install Libzstd:
sudo apt-get install -y libzstd-dev
Building and Testing
- Build the solution:
dotnet build
(dotnet core sdk required) This will install required tools and then you can use any IDE to build solution - Make your modifications
- Run unit tests:
cd tests/UnitTests
&&dotnet test
- (Optional) If changes are made in Client logic, run Integration tests. Before running do the following
- Install pulsar cluster:
- MacOS guide:
brew tap streamlio/homebrew-formulae
brew install streamlio/homebrew-formulae/pulsar
brew install streamlio/homebrew-formulae/bookkeeper
brew services start pulsar
brew services start bookkeeper
- Run commands in
/tests/IntegrationTests/commands.txt
- Change
pulsarAddress
in Common.fs to point your pulsar cluster - Ensure
public/default
namespace with default settings - Ensure
public/retention
namespace with time or storage size retention configured
- Install pulsar cluster:
- Send a Pull Request
Maintaners
- @Lanayx
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Apache.Avro (>= 1.11.2)
- AvroSchemaGenerator (>= 2.9.2)
- FSharp.Core (>= 7.0.400)
- FSharp.UMX (>= 1.1.0)
- K4os.Compression.LZ4 (>= 1.3.6)
- Microsoft.Bcl.AsyncInterfaces (>= 7.0.0)
- Microsoft.Extensions.Caching.Memory (>= 7.0.0)
- Microsoft.Extensions.Http (>= 7.0.0)
- Microsoft.Extensions.Logging (>= 7.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 7.0.1)
- Microsoft.IO.RecyclableMemoryStream (>= 2.3.2)
- NSec.Cryptography (= 20.2.0)
- PemUtils (>= 3.0.0.82)
- Pipelines.Sockets.Unofficial (>= 2.2.8)
- protobuf-net (>= 3.2.26)
- protobuf-net.Reflection (>= 3.2.12)
- Snappy.Standard (>= 0.2.0)
- System.IO.Pipelines (>= 7.0.0)
- System.Text.Json (>= 7.0.3)
- System.Threading.Channels (>= 7.0.0)
- zlib.net-mutliplatform (>= 1.0.6)
- ZstdNet (>= 1.4.5)
NuGet packages (9)
Showing the top 5 NuGet packages that depend on Pulsar.Client:
Package | Downloads |
---|---|
Pulsar.Client.Otel
OpenTelemetry plugin for Pulsar.Client |
|
Zq.Utils.Core
.NET Standard2.0、.NET Standard2.1、.NET5、.NET6版本工具类 |
|
DotNetCore.CAP.Pulsar
Distributed transaction solution in micro-service base on eventually consistency, also an eventbus with Outbox pattern. |
|
SnD.Sdk
SDK for Sneaks&Data OSS Projects |
|
RJ.Commons.Pulsar
Default Pulsar API for Aries project. |
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on Pulsar.Client:
Repository | Stars |
---|---|
dotnetcore/CAP
Distributed transaction solution in micro-service base on eventually consistency, also an eventbus with Outbox pattern
|
|
LeonKou/NetPro
🌈An enhanced version with clean architecture of asp.netcore,efficiently manage startup,Support for netcore3.1/6.0
|
Version | Downloads | Last updated |
---|---|---|
3.6.2 | 3,719 | 12/9/2024 |
3.6.1 | 12,182 | 11/21/2024 |
3.6.0 | 84,655 | 8/8/2024 |
3.5.4 | 8,765 | 8/1/2024 |
3.5.3 | 1,792 | 7/31/2024 |
3.5.2 | 7,691 | 7/15/2024 |
3.5.1 | 8,836 | 6/19/2024 |
3.5.0 | 6,188 | 5/15/2024 |
3.4.0 | 3,719 | 4/19/2024 |
3.3.1 | 3,005 | 3/28/2024 |
3.3.0 | 37,807 | 2/12/2024 |
3.2.0 | 1,805 | 2/1/2024 |
3.1.0 | 19,368 | 11/19/2023 |
3.0.0 | 776 | 11/17/2023 |
3.0.0-beta.2 | 159 | 10/22/2023 |
3.0.0-beta.1 | 122 | 10/15/2023 |
2.17.0 | 118 | 12/26/2024 |
2.16.0 | 8,420 | 4/29/2024 |
2.15.2 | 1,980 | 3/7/2024 |
2.15.1 | 712 | 2/12/2024 |
2.15.0 | 41,863 | 11/18/2023 |
2.14.0 | 1,099 | 11/14/2023 |
2.13.2 | 33,735 | 10/11/2023 |
2.13.1 | 3,431 | 9/29/2023 |
2.13.0 | 34,818 | 9/25/2023 |
2.12.7 | 20,703 | 8/9/2023 |
2.12.6 | 42,994 | 7/23/2023 |
2.12.4 | 4,757 | 7/17/2023 |
2.12.3 | 17,104 | 7/6/2023 |
2.12.2 | 107,523 | 3/31/2023 |
2.12.1 | 19,089 | 3/22/2023 |
2.12.0 | 10,648 | 1/29/2023 |
2.11.0 | 38,472 | 10/13/2022 |
2.10.4 | 8,713 | 10/7/2022 |
2.10.3 | 2,883 | 9/16/2022 |
2.10.2 | 53,248 | 6/22/2022 |
2.10.1 | 64,616 | 3/9/2022 |
2.10.0 | 40,817 | 2/23/2022 |
2.9.4 | 20,650 | 12/5/2021 |
2.9.3 | 3,494 | 11/26/2021 |
2.9.2 | 1,194 | 11/11/2021 |
2.9.1 | 29,816 | 10/14/2021 |
2.9.0 | 2,065 | 9/29/2021 |
2.8.1 | 5,375 | 9/9/2021 |
2.8.0 | 2,167 | 9/2/2021 |
2.7.2 | 8,535 | 8/26/2021 |
2.7.1 | 7,367 | 8/6/2021 |
2.7.0 | 7,238 | 7/20/2021 |
2.6.3 | 2,057 | 7/15/2021 |
2.6.2 | 1,939 | 7/9/2021 |
2.6.1 | 1,328 | 7/6/2021 |
2.6.0 | 6,671 | 7/5/2021 |
2.5.3 | 1,152 | 7/2/2021 |
2.5.2 | 1,289 | 6/30/2021 |
2.5.1 | 1,590 | 6/29/2021 |
2.5.0 | 1,233 | 6/27/2021 |
2.4.1 | 1,436 | 6/25/2021 |
2.4.0 | 2,586 | 6/14/2021 |
2.3.3 | 1,544 | 6/8/2021 |
2.3.1 | 2,753 | 5/11/2021 |
2.3.0 | 1,301 | 5/11/2021 |
2.2.0 | 2,180 | 4/22/2021 |
2.1.1 | 1,262 | 4/14/2021 |
2.1.0 | 4,595 | 3/16/2021 |
2.0.4 | 2,266 | 3/5/2021 |
2.0.3 | 1,265 | 3/5/2021 |
2.0.2 | 2,562 | 2/23/2021 |
2.0.1 | 9,267 | 2/17/2021 |
2.0.0 | 1,263 | 2/12/2021 |
1.8.5 | 9,365 | 2/10/2021 |
1.8.4 | 25,191 | 1/25/2021 |
1.8.3 | 2,320 | 1/6/2021 |
1.8.2 | 3,325 | 12/17/2020 |
1.8.1 | 4,389 | 12/15/2020 |
1.8.0 | 3,982 | 12/10/2020 |
1.7.8 | 78,931 | 5/17/2021 |
1.7.7 | 1,189 | 5/17/2021 |
1.7.6 | 1,264 | 5/17/2021 |
1.7.5 | 3,100 | 10/30/2020 |
1.7.4 | 6,753 | 10/19/2020 |
1.7.3 | 28,046 | 10/13/2020 |
1.7.2 | 1,745 | 10/2/2020 |
1.7.1 | 4,870 | 9/17/2020 |
1.7.0 | 1,566 | 9/14/2020 |
1.6.3 | 1,374 | 9/12/2020 |
1.6.2 | 1,465 | 9/3/2020 |
1.6.1 | 1,330 | 9/2/2020 |
1.6.0 | 1,479 | 8/30/2020 |
1.5.0 | 10,778 | 8/3/2020 |
1.4.3 | 2,460 | 7/9/2020 |
1.4.2 | 1,538 | 7/2/2020 |
1.4.1 | 1,249 | 6/29/2020 |
1.4.0 | 1,706 | 6/17/2020 |
1.3.0 | 1,457 | 6/14/2020 |
1.2.0 | 2,817 | 5/27/2020 |
1.1.1 | 1,354 | 5/22/2020 |
1.1.0 | 1,945 | 5/15/2020 |
1.0.1 | 1,310 | 5/14/2020 |
1.0.0 | 1,326 | 5/14/2020 |
0.18.4 | 1,873 | 4/21/2020 |
0.18.3 | 1,511 | 4/18/2020 |
0.18.2 | 3,237 | 4/8/2020 |
0.18.1 | 1,345 | 4/7/2020 |
0.18.0 | 1,543 | 4/1/2020 |
0.17.0 | 1,539 | 3/21/2020 |
0.16.0 | 1,382 | 3/19/2020 |
0.15.0 | 1,968 | 2/28/2020 |
0.14.1 | 1,366 | 2/25/2020 |
0.14.0 | 1,300 | 2/21/2020 |
0.13.1 | 1,341 | 2/19/2020 |
0.13.0 | 1,700 | 2/14/2020 |
0.12.0 | 2,047 | 12/31/2019 |
0.11.2 | 1,535 | 12/23/2019 |
0.11.1 | 1,453 | 12/20/2019 |
0.11.0 | 1,399 | 12/16/2019 |
0.10.0 | 1,469 | 11/17/2019 |
0.9.1 | 1,534 | 11/14/2019 |
0.9.0 | 1,453 | 11/12/2019 |
0.8.2 | 1,477 | 11/9/2019 |
0.8.1 | 1,468 | 11/4/2019 |
0.8.0 | 1,398 | 11/2/2019 |
0.7.0 | 1,423 | 10/25/2019 |
0.6.0 | 1,488 | 10/16/2019 |
0.5.0 | 1,416 | 10/15/2019 |
0.4.0 | 1,445 | 10/8/2019 |
0.3.0 | 1,418 | 10/7/2019 |
0.2.0 | 1,538 | 9/30/2019 |
0.1.5 | 1,280 | 9/13/2019 |
0.1.4 | 1,245 | 9/9/2019 |
0.1.3 | 1,222 | 9/9/2019 |
0.1.2 | 1,182 | 9/9/2019 |
0.1.1 | 1,298 | 9/6/2019 |
0.1.0 | 1,287 | 9/6/2019 |
Support for new (from 2.9) transaction protocol