Crdt.Transport.NanoMsg
1.0.3
dotnet add package Crdt.Transport.NanoMsg --version 1.0.3
NuGet\Install-Package Crdt.Transport.NanoMsg -Version 1.0.3
<PackageReference Include="Crdt.Transport.NanoMsg" Version="1.0.3" />
<PackageVersion Include="Crdt.Transport.NanoMsg" Version="1.0.3" />
<PackageReference Include="Crdt.Transport.NanoMsg" />
paket add Crdt.Transport.NanoMsg --version 1.0.3
#r "nuget: Crdt.Transport.NanoMsg, 1.0.3"
#:package Crdt.Transport.NanoMsg@1.0.3
#addin nuget:?package=Crdt.Transport.NanoMsg&version=1.0.3
#tool nuget:?package=Crdt.Transport.NanoMsg&version=1.0.3
Crdt
High-performance, NativeAOT-ready Conflict-free Replicated Data Types (CRDTs) for modern .NET.
Crdt implements the full catalogue of CRDTs — counters, registers, sets, maps, flags, graphs, trees, JSON documents, and sequence/text types — in state-based, delta-state, and operation-based flavours, with compact binary and System.Text.Json source-generated serialization. It also includes advanced/esoteric variants (bounded, resettable, and handoff counters, causal-length sets, a tree with move, Fugue, and interval tree clocks).
✨ Why Crdt
- Strong eventual consistency without coordination: replicas converge after exchanging state, deltas, or operations.
- Fast:
readonly structbuilding blocks,Span<T>/IBufferWriter<byte>serialization,BinaryPrimitives/Unsafefast paths, no LINQ on hot paths. - NativeAOT & trimming clean on .NET 8/9/10 — the library is annotated
IsAotCompatible, and the test suite itself is verified running as a NativeAOT binary. - Broad reach: targets
netstandard2.0,netstandard2.1,net8.0,net9.0,net10.0(polyfilled on older runtimes).
Supported target frameworks
| TFM | Notes |
|---|---|
net10.0, net9.0, net8.0 |
Full feature set; NativeAOT supported. |
netstandard2.1 |
Compatibility target (Unity / Mono / .NET Core 3.x) via polyfills; not itself AOT-published. |
netstandard2.0 |
Broad compatibility target (.NET Framework 4.6.1+, older Unity / Mono) via System.Memory + Microsoft.Bcl.HashCode and source polyfills; not AOT-published. |
📦 Install
dotnet add package Crdt
The optional replication/transport layer — in-memory, TCP (with optional TLS), and UDP anti-entropy gossip, in state-based, delta-state, and operation-based modes — ships as a separate package:
dotnet add package Crdt.Transport
DTLS-secured datagram gossip (built on DtlsSharp) lives in a further opt-in package:
dotnet add package Crdt.Transport.Dtls
MQTT broker gossip (built on Mqtt.Client) — for replicas that reach each other through an MQTT 3.1.1/5.0 broker rather than peer-to-peer — ships as another opt-in package:
dotnet add package Crdt.Transport.Mqtt
Peer-to-peer gossip over the nanomsg/NNG BUS scalability protocol (built on NanoMsgSharp, pure-managed, no broker) — over TCP, TLS, IPC, WebSockets, or in-process — ships as another opt-in package:
dotnet add package Crdt.Transport.NanoMsg
🧩 CRDT catalogue
| Family | Types |
|---|---|
| Counters | GCounter, PNCounter, BCounter, ResettableCounter, HandoffCounter |
| Registers | LWWRegister<T>, MVRegister<T> |
| Sets | GSet<T>, TwoPhaseSet<T>, LWWElementSet<T>, ORSet<T>, CausalLengthSet<T> |
| Maps | ORMap<TKey,TValue>, LWWMap<TKey,TValue> |
| Flags | EnableWinsFlag, DisableWinsFlag, GFlag |
| Graphs | TwoPTwoPGraph, AddOnlyDag |
| Trees | ReplicatedTree (highly-available move) |
| Documents | JsonCrdt (nested JSON) |
| Sequences / Text | Rga<T>, LogootSequence<T>, LSeqSequence<T>, TreedocSequence<T>, YataSequence<T>, WootSequence<T>, FugueSequence<T>, Text |
| Causal clocks | HybridLogicalClock, VersionVector, IntervalTreeClock |
The Counters, Sets, Trees, Documents, Sequences, and Causal clocks rows include several advanced / esoteric CRDTs (bounded, resettable, and handoff counters; causal-length set; tree-with-move; JSON document; Fugue; interval tree clocks). See Advanced / esoteric CRDTs for what each one is for.
🔁 Replication models
- State-based (CvRDT) — exchange and
Mergefull states. Robust to reordering and duplication. - Delta-state — propagate small deltas of the same lattice; converges with a causal delta protocol.
- Operation-based (CmRDT) — propagate operations carrying their causal context; effects are idempotent / de-duplicated.
Crdt provides the data structures, merge/delta/operation logic, and serialization. Wiring replicas to a network (gossip, anti-entropy, broadcast) is left to the application.
📚 Documentation
- Getting started — install, your first counter, merging replicas.
- Data types — the full catalogue with usage examples for every CRDT.
- Replication models — state-based, delta-state, and operation-based, and when to use each.
- Serialization — the binary and JSON formats, value serializers, and hostile-input limits.
- Architecture — semilattices, dots, the causal kernel (ORSWOT), and the Hybrid Logical Clock.
- Performance & NativeAOT — AOT compliance, trimming, and benchmarking notes.
- Transports — the optional
Crdt.Transportpackage: in-memory, TCP/UDP, DTLS-secured, MQTT broker, and nanomsg/NNG BUS gossip replication.
🛠️ Building from source
dotnet build Crdt.slnx -c Release
dotnet test Crdt.slnx -c Release
Linting / formatting:
dotnet format Crdt.slnx --verify-no-changes
pwsh -NoProfile -File eng/check-line-length.ps1
NativeAOT test gate (publishes and runs the suite as a native binary):
dotnet publish tests/Crdt.Tests/Crdt.Tests.csproj -c Release -f net10.0 -r <rid> -p:AotTest=true
📄 License
| 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 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. net9.0 is compatible. 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. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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 is compatible. |
| .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
- Crdt.Transport (>= 1.0.3)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.9)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- Microsoft.Bcl.TimeProvider (>= 10.0.9)
- NanoMsgSharp (>= 1.0.0)
- System.Memory (>= 4.6.3)
- System.Runtime.CompilerServices.Unsafe (>= 6.1.2)
- System.Text.Json (>= 10.0.9)
- System.Threading.Channels (>= 10.0.9)
- System.Threading.Tasks.Extensions (>= 4.6.3)
-
.NETStandard 2.1
- Crdt.Transport (>= 1.0.3)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.9)
- Microsoft.Bcl.TimeProvider (>= 10.0.9)
- NanoMsgSharp (>= 1.0.0)
- System.Runtime.CompilerServices.Unsafe (>= 6.1.2)
- System.Text.Json (>= 10.0.9)
- System.Threading.Channels (>= 10.0.9)
-
net10.0
- Crdt.Transport (>= 1.0.3)
- NanoMsgSharp (>= 1.0.0)
-
net8.0
- Crdt.Transport (>= 1.0.3)
- NanoMsgSharp (>= 1.0.0)
-
net9.0
- Crdt.Transport (>= 1.0.3)
- NanoMsgSharp (>= 1.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.3 | 40 | 6/27/2026 |