NATS.Net
2.2.2
Prefix Reserved
See the version list below for details.
dotnet add package NATS.Net --version 2.2.2
NuGet\Install-Package NATS.Net -Version 2.2.2
<PackageReference Include="NATS.Net" Version="2.2.2" />
paket add NATS.Net --version 2.2.2
#r "nuget: NATS.Net, 2.2.2"
// Install NATS.Net as a Cake Addin #addin nuget:?package=NATS.Net&version=2.2.2 // Install NATS.Net as a Cake Tool #tool nuget:?package=NATS.Net&version=2.2.2
NATS .NET
NATS .NET is a client library designed to connect to the NATS messaging server, fully supporting all NATS features. It integrates seamlessly with modern .NET asynchronous interfaces such as async enumerables and channels, and leverages advanced .NET memory, buffer and IO features.
Check out NATS .NET client library documentation for guides and examples.
What is NATS?
NATS is a high-performance, secure, distributed messaging system. It's a connective technology tailored for modern distributed systems, facilitating efficient addressing, discovery, and message exchange. It supports dynamic service and stream processing across various locations and devices, enhancing mobility, security, and independence from traditional constraints such as DNS.
Head over to NATS documentation for more information.
Quick Start
Basic messaging:
// NATS core M:N messaging example
await using var nats = new NatsConnection();
// Subscribe on one terminal
await foreach (var msg in nats.SubscribeAsync<string>(subject: "foo"))
{
Console.WriteLine($"Received: {msg.Data}");
}
// Start publishing to the same subject on a second terminal
await nats.PublishAsync(subject: "foo", data: "Hello, World!");
Persistance with JetStream:
await using var nats = new NatsConnection();
var js = new NatsJSContext(nats);
// Create a stream to store the messages
await js.CreateStreamAsync(new StreamConfig(name: "orders", subjects: new[] { "orders.*" }));
// Publish a message to the stream. The message will be stored in the stream
// because the published subject matches one of the the stream's subjects.
var ack = await js.PublishAsync(subject: "orders.new", data: "order 1");
ack.EnsureSuccess();
// Create a consumer on a stream to receive the messages
var consumer = await js.CreateOrUpdateConsumerAsync("orders", new ConsumerConfig("order_processor"));
await foreach (var jsMsg in consumer.ConsumeAsync<string>())
{
Console.WriteLine($"Processed: {jsMsg.Data}");
await jsMsg.AckAsync();
}
See more details, including how to download and start NATS server and JetStream in our documentation.
Additionally check out NATS by example - An evolving collection of runnable, cross-client reference examples for NATS.
NATS .NET Goals
- Only support Async I/O (async/await)
- Target current .NET LTS releases (currently .NET 6.0 & .NET 8.0)
Packages
- NATS.Net: Meta package that includes all other packages (except serialization)
- NATS.Client.Core: Core NATS
- NATS.Client.JetStream: JetStream
- NATS.Client.KeyValueStore: Key/Value Store
- NATS.Client.ObjectStore: Object Store
- NATS.Client.Services: Services
- NATS.Extensions.Microsoft.DependencyInjection: extension to configure DI container
- NATS.Client.Serializers.Json: JSON serializer for ad-hoc types
Contributing
- Run
dotnet format
at root directory of project in order to clear warnings that can be auto-formatted - Run
dotnet build
at root directory and make sure there are no errors or warnings
Find us on slack.nats.io dotnet channel
Please also check out the Contributor Guide and Code of Conduct.
Attribution
This library is based on the excellent work in Cysharp/AlterNats
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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 is compatible. 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. |
-
net6.0
- NATS.Client.Core (>= 2.2.2)
- NATS.Client.Hosting (>= 2.2.2)
- NATS.Client.JetStream (>= 2.2.2)
- NATS.Client.KeyValueStore (>= 2.2.2)
- NATS.Client.ObjectStore (>= 2.2.2)
- NATS.Client.Services (>= 2.2.2)
-
net8.0
- NATS.Client.Core (>= 2.2.2)
- NATS.Client.Hosting (>= 2.2.2)
- NATS.Client.JetStream (>= 2.2.2)
- NATS.Client.KeyValueStore (>= 2.2.2)
- NATS.Client.ObjectStore (>= 2.2.2)
- NATS.Client.Services (>= 2.2.2)
NuGet packages (16)
Showing the top 5 NuGet packages that depend on NATS.Net:
Package | Downloads |
---|---|
NATS.Extensions.Microsoft.DependencyInjection
ASP.NET Core and Generic Host support for NATS.Net. |
|
Codecabinet.sni.Common.Implementation
Package Description |
|
Neon.SignalR
SignalR helpers and utilities. Includes NATS backplane and a smart load balancer. |
|
Aspire.Hosting.Nats
NATS support for .NET Aspire. |
|
Aspire.NATS.Net
A NATS client that integrates with Aspire, including health checks and logging. |
GitHub repositories (3)
Showing the top 3 popular GitHub repositories that depend on NATS.Net:
Repository | Stars |
---|---|
dotnet/aspire
Tools, templates, and packages to accelerate building observable, production-ready apps
|
|
zarusz/SlimMessageBus
Lightweight message bus interface for .NET (pub/sub and request-response) with transport plugins for popular message brokers.
|
|
dotnet/dotnet
Home of .NET's Virtual Monolithic Repository which includes all the code needed to build the .NET SDK from source
|
Version | Downloads | Last updated |
---|---|---|
2.5.4 | 2,437 | 11/13/2024 |
2.5.3 | 6,568 | 11/5/2024 |
2.5.2 | 8,651 | 10/22/2024 |
2.5.1 | 11,495 | 10/17/2024 |
2.5.0 | 9,986 | 10/9/2024 |
2.5.0-preview.2 | 59 | 10/8/2024 |
2.5.0-preview.1 | 102 | 10/1/2024 |
2.4.0 | 14,055 | 9/17/2024 |
2.4.0-preview.3 | 74 | 9/11/2024 |
2.4.0-preview.2 | 95 | 8/23/2024 |
2.4.0-preview.1 | 1,587 | 8/5/2024 |
2.3.3 | 51,405 | 8/2/2024 |
2.3.3-preview.4 | 163 | 7/26/2024 |
2.3.3-preview.3 | 111 | 7/25/2024 |
2.3.3-preview.2 | 58 | 7/24/2024 |
2.3.3-preview.1 | 164 | 7/18/2024 |
2.3.2 | 28,388 | 7/10/2024 |
2.3.1 | 2,523 | 7/9/2024 |
2.3.1-preview.2 | 65 | 7/8/2024 |
2.3.1-preview.1 | 67 | 7/6/2024 |
2.3.0 | 18,897 | 7/3/2024 |
2.3.0-preview.1 | 117 | 6/24/2024 |
2.2.3 | 22,780 | 6/11/2024 |
2.2.2 | 14,981 | 5/23/2024 |
2.2.1 | 66,594 | 4/17/2024 |
2.2.0 | 14,239 | 4/4/2024 |
2.1.4 | 16,418 | 3/19/2024 |
2.1.3 | 5,005 | 3/12/2024 |
2.1.2 | 24,446 | 2/27/2024 |
2.1.1 | 4,290 | 2/20/2024 |
2.1.0 | 14,549 | 2/10/2024 |
2.1.0-preview.7 | 86 | 2/8/2024 |
2.1.0-preview.6 | 90 | 2/2/2024 |
2.1.0-preview.5 | 1,341 | 1/25/2024 |
2.1.0-preview.4 | 72 | 1/23/2024 |
2.1.0-preview.3 | 168 | 1/18/2024 |
2.1.0-preview.2 | 211 | 1/12/2024 |
2.1.0-preview.1 | 74 | 1/11/2024 |
2.0.3 | 64,132 | 1/5/2024 |
2.0.3-preview.1 | 106 | 12/22/2023 |
2.0.2 | 2,795 | 12/15/2023 |
2.0.2-preview.2 | 79 | 12/12/2023 |
2.0.2-preview.1 | 763 | 12/6/2023 |
2.0.1 | 16,692 | 11/29/2023 |
2.0.0 | 944 | 11/23/2023 |
2.0.0-rc.2 | 85 | 11/21/2023 |
2.0.0-rc.1 | 111 | 11/17/2023 |