Akka.Cluster.Sharding
1.4.21-beta1
Prefix Reserved
See the version list below for details.
dotnet add package Akka.Cluster.Sharding --version 1.4.21-beta1
NuGet\Install-Package Akka.Cluster.Sharding -Version 1.4.21-beta1
<PackageReference Include="Akka.Cluster.Sharding" Version="1.4.21-beta1" />
paket add Akka.Cluster.Sharding --version 1.4.21-beta1
#r "nuget: Akka.Cluster.Sharding, 1.4.21-beta1"
// Install Akka.Cluster.Sharding as a Cake Addin #addin nuget:?package=Akka.Cluster.Sharding&version=1.4.21-beta1&prerelease // Install Akka.Cluster.Sharding as a Cake Tool #tool nuget:?package=Akka.Cluster.Sharding&version=1.4.21-beta1&prerelease
Sharded actors with managed lifecycle for Akka.NET cluster
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
- Akka.Cluster.Tools (>= 1.4.21-beta1)
- Akka.Coordination (>= 1.4.21-beta1)
- Akka.DistributedData (>= 1.4.21-beta1)
- Akka.DistributedData.LightningDB (>= 1.4.21-beta1)
- Akka.Persistence (>= 1.4.21-beta1)
NuGet packages (16)
Showing the top 5 NuGet packages that depend on Akka.Cluster.Sharding:
Package | Downloads |
---|---|
Akka.Cluster.Hosting
Akka.Cluster and Akka.Cluster.Sharding Microsoft.Extensions.Hosting support. |
|
Petabridge.Cmd.Cluster.Sharding
Akka.Cluster.Sharding Petabridge.Cmd palettes for shard management and monitoring. |
|
wyvern.entity
Package Description |
|
Akkling.Cluster.Sharding
F# wrapper library for Akka.NET cluster sharding module. |
|
Akkatecture.Clustering
clustering library for akkatecture to enable distributed scenarios |
GitHub repositories (4)
Showing the top 4 popular GitHub repositories that depend on Akka.Cluster.Sharding:
Repository | Stars |
---|---|
petabridge/akkadotnet-code-samples
Akka.NET professional reference code samples
|
|
ThembisileNGQ/Akkatecture
a cqrs and event sourcing framework for dotnet core using akka.net
|
|
Aaronontheweb/InMemoryCQRSReplication
Akka.NET Reference Architecture - CQRS + Sharding + In-Memory Replication
|
|
Horusiath/AkkaCQRS
Event sourcing example build on Akka.NET with persistence plugin
|
Version | Downloads | Last updated |
---|---|---|
1.5.35 | 2,197 | 1/13/2025 |
1.5.34 | 1,244 | 1/7/2025 |
1.5.33 | 3,259 | 12/23/2024 |
1.5.32 | 7,044 | 12/4/2024 |
1.5.31 | 10,663 | 11/11/2024 |
1.5.30 | 19,971 | 10/3/2024 |
1.5.29 | 1,615 | 10/1/2024 |
1.5.28 | 35,231 | 9/4/2024 |
1.5.28-beta1 | 135 | 8/23/2024 |
1.5.27.1 | 49,010 | 7/26/2024 |
1.5.27 | 503 | 7/25/2024 |
1.5.27-beta2 | 115 | 7/3/2024 |
1.5.27-beta1 | 92 | 7/3/2024 |
1.5.26 | 43,773 | 6/27/2024 |
1.5.25 | 58,519 | 6/14/2024 |
1.5.24 | 5,627 | 6/7/2024 |
1.5.23 | 704 | 6/6/2024 |
1.5.22 | 1,749 | 6/3/2024 |
1.5.21 | 3,371 | 5/28/2024 |
1.5.20 | 23,205 | 4/29/2024 |
1.5.19 | 13,018 | 4/15/2024 |
1.5.18 | 35,069 | 3/12/2024 |
1.5.17.1 | 7,228 | 3/2/2024 |
1.5.17 | 822 | 2/29/2024 |
1.5.16 | 20,119 | 1/29/2024 |
1.5.15 | 28,563 | 1/10/2024 |
1.5.14 | 27,518 | 11/3/2023 |
1.5.13 | 65,414 | 9/18/2023 |
1.5.13-beta1 | 443 | 8/25/2023 |
1.5.12 | 21,807 | 8/2/2023 |
1.5.11 | 3,121 | 7/27/2023 |
1.5.10 | 7,468 | 7/25/2023 |
1.5.9 | 8,341 | 7/17/2023 |
1.5.8 | 35,601 | 6/15/2023 |
1.5.7 | 21,687 | 5/17/2023 |
1.5.6 | 9,459 | 5/8/2023 |
1.5.5 | 35,565 | 5/4/2023 |
1.5.4 | 12,552 | 4/25/2023 |
1.5.3 | 2,822 | 4/20/2023 |
1.5.2 | 17,302 | 4/6/2023 |
1.5.1 | 8,569 | 3/15/2023 |
1.5.0 | 11,553 | 3/2/2023 |
1.5.0-beta6 | 1,001 | 3/1/2023 |
1.5.0-beta5 | 555 | 3/1/2023 |
1.5.0-beta4 | 646 | 2/28/2023 |
1.5.0-beta3 | 728 | 2/27/2023 |
1.5.0-beta2 | 575 | 2/23/2023 |
1.5.0-beta1 | 606 | 2/20/2023 |
1.5.0-alpha4 | 955 | 2/1/2023 |
1.5.0-alpha3 | 799 | 11/15/2022 |
1.5.0-alpha2 | 679 | 10/17/2022 |
1.5.0-alpha1 | 682 | 8/22/2022 |
1.4.51 | 10,191 | 6/28/2023 |
1.4.50 | 4,391 | 3/15/2023 |
1.4.49 | 15,352 | 1/27/2023 |
1.4.49-beta1 | 610 | 1/11/2023 |
1.4.48 | 28,241 | 1/5/2023 |
1.4.47 | 9,830 | 12/9/2022 |
1.4.46 | 25,999 | 11/15/2022 |
1.4.45 | 22,805 | 10/19/2022 |
1.4.44 | 2,620 | 10/17/2022 |
1.4.43 | 11,226 | 9/27/2022 |
1.4.42 | 2,284 | 9/23/2022 |
1.4.41 | 135,029 | 8/31/2022 |
1.4.40 | 13,668 | 7/22/2022 |
1.4.39 | 86,134 | 6/1/2022 |
1.4.38 | 42,815 | 5/6/2022 |
1.4.37 | 11,004 | 4/14/2022 |
1.4.36 | 9,710 | 4/5/2022 |
1.4.35 | 21,709 | 3/18/2022 |
1.4.34 | 7,463 | 3/7/2022 |
1.4.33 | 7,945 | 2/14/2022 |
1.4.32 | 13,271 | 1/18/2022 |
1.4.31 | 29,156 | 12/21/2021 |
1.4.30 | 1,652 | 12/20/2021 |
1.4.29 | 2,051 | 12/13/2021 |
1.4.28 | 50,680 | 11/10/2021 |
1.4.27 | 44,639 | 10/11/2021 |
1.4.26 | 4,629 | 9/28/2021 |
1.4.25 | 5,696 | 9/8/2021 |
1.4.24 | 8,526 | 8/17/2021 |
1.4.23 | 3,543 | 8/10/2021 |
1.4.22 | 5,918 | 8/5/2021 |
1.4.21 | 19,094 | 6/16/2021 |
1.4.21-beta1 | 886 | 6/4/2021 |
1.4.20 | 14,429 | 5/12/2021 |
1.4.19 | 13,926 | 4/28/2021 |
1.4.18 | 10,647 | 3/23/2021 |
1.4.17 | 6,117 | 3/10/2021 |
1.4.16 | 29,169 | 1/22/2021 |
1.4.15 | 2,391 | 1/20/2021 |
1.4.14 | 10,227 | 12/30/2020 |
1.4.13 | 3,116 | 12/16/2020 |
1.4.12 | 18,938 | 11/16/2020 |
1.4.11 | 12,394 | 11/5/2020 |
1.4.10 | 18,694 | 8/20/2020 |
1.4.9 | 15,068 | 7/21/2020 |
1.4.8 | 47,017 | 6/17/2020 |
1.4.7 | 5,631 | 5/27/2020 |
1.4.6 | 6,640 | 5/12/2020 |
1.4.5 | 4,321 | 4/29/2020 |
1.4.4 | 8,362 | 3/31/2020 |
1.4.3 | 4,968 | 3/18/2020 |
1.4.2 | 4,209 | 3/13/2020 |
1.4.1 | 9,017 | 3/11/2020 |
1.4.1-rc3 | 1,015 | 3/10/2020 |
1.4.1-rc2 | 833 | 3/10/2020 |
1.4.1-rc1 | 1,253 | 2/28/2020 |
1.4.0-beta4 | 2,445 | 1/28/2020 |
1.4.0-beta3 | 7,022 | 10/30/2019 |
1.4.0-beta2 | 3,811 | 9/23/2019 |
1.4.0-beta1 | 2,598 | 7/19/2019 |
1.4.0-beta | 1,056 | 10/30/2019 |
1.3.19-beta | 78 | 5/2/2024 |
1.3.18-beta | 10,657 | 3/9/2020 |
1.3.17-beta | 6,763 | 12/20/2019 |
1.3.16-beta | 2,938 | 11/14/2019 |
1.3.15-beta | 4,587 | 9/23/2019 |
1.3.14-beta | 7,307 | 7/30/2019 |
1.3.13-beta | 19,433 | 4/30/2019 |
1.3.12-beta | 12,768 | 3/14/2019 |
1.3.11-beta | 10,592 | 12/18/2018 |
1.3.10-beta | 83,555 | 11/2/2018 |
1.3.9-beta68 | 40,524 | 8/23/2018 |
1.3.9-beta67 | 1,216 | 8/23/2018 |
1.3.9-beta | 1,156 | 8/30/2018 |
1.3.8-beta66 | 8,811 | 6/5/2018 |
1.3.8-beta65 | 1,345 | 6/5/2018 |
1.3.7-beta64 | 1,952 | 5/15/2018 |
1.3.7-beta63 | 1,426 | 5/15/2018 |
1.3.6-beta62 | 3,399 | 4/17/2018 |
1.3.6-beta61 | 1,311 | 4/17/2018 |
1.3.5-beta60 | 8,837 | 2/22/2018 |
1.3.5-beta59 | 1,348 | 2/22/2018 |
1.3.4-beta58 | 1,576 | 2/1/2018 |
1.3.4-beta57 | 1,396 | 2/1/2018 |
1.3.3-beta56 | 1,517 | 1/19/2018 |
1.3.3-beta55 | 1,425 | 1/19/2018 |
1.3.2-beta54 | 20,401 | 10/21/2017 |
1.3.2-beta53 | 1,355 | 10/21/2017 |
1.3.2-beta | 2,207 | 10/24/2017 |
1.3.1-beta52 | 2,149 | 9/5/2017 |
1.3.1-beta51 | 1,328 | 9/5/2017 |
1.3.0-beta50 | 1,411 | 8/18/2017 |
1.3.0-beta48 | 1,297 | 8/17/2017 |
1.3.0-beta47 | 1,360 | 8/17/2017 |
1.3.0-beta46 | 1,350 | 8/11/2017 |
1.2.3.43-beta | 2,918 | 7/10/2017 |
1.2.3.41-beta | 1,355 | 7/10/2017 |
1.2.2.40-beta | 1,404 | 6/28/2017 |
1.2.2.39-beta | 1,316 | 6/28/2017 |
1.2.1.38-beta | 1,355 | 6/23/2017 |
1.2.1.37-beta | 1,392 | 6/23/2017 |
1.2.0.36-beta | 10,831 | 4/13/2017 |
1.2.0.35-beta | 1,577 | 4/13/2017 |
1.2.0.34-beta | 1,300 | 4/12/2017 |
1.2.0.33-beta | 1,942 | 4/12/2017 |
1.1.3.32-beta | 2,649 | 1/23/2017 |
1.1.3.31-beta | 1,547 | 1/23/2017 |
1.1.2.30-beta | 3,047 | 9/22/2016 |
1.1.2.29-beta | 1,686 | 9/22/2016 |
1.1.1.28-beta | 1,467 | 7/16/2016 |
1.1.1.27-beta | 1,422 | 7/16/2016 |
1.1.0.26-beta | 1,475 | 7/7/2016 |
1.0.8.25-beta | 3,171 | 4/26/2016 |
1.0.8.24-beta | 1,446 | 4/26/2016 |
1.0.7.18-beta | 1,463 | 4/6/2016 |
Maintenance Release for Akka.NET 1.4**
Akka.NET v1.4.21 is a significant release that includes major performance improvements, bug fixes, and a major update to the [Akka.DependencyInjection NuGet package](https://getakka.net/articles/actors/dependency-injection.html).
Performance Improvements**
Akka.NET v1.4.21 includes some major performance fixes and improvements:
[`Ask` is now ~10% faster](https://github.com/akkadotnet/akka.net/pull/5051)
[`MurmurHash` is 33% faster and allocates 0 memory](https://github.com/akkadotnet/akka.net/pull/5028) - used _heavily_ in DData, Cluster Sharding, and Consistent Hash Routers
`ActorPath.Parse` went from 1672 ns/op to 527 ns/op - a 68% improvement in throughput and a 50% reduction in memory. See [#5039](https://github.com/akkadotnet/akka.net/pull/5039) and [#5068](https://github.com/akkadotnet/akka.net/pull/5068).
[Akka.Remote: remove `ActorPath.ToString` call from `ResolveActorRefWithLocalAddress`](https://github.com/akkadotnet/akka.net/pull/5034)
Important**: [Revert `ThreadPool.SetMinThreads(0,0)`](https://github.com/akkadotnet/akka.net/pull/5059) - based on the input from users on "[Akka.NET v1.4.19: ChannelExecutor performance data](https://github.com/akkadotnet/akka.net/discussions/4983)"
Our observed performance numbers for Akka.Remote show a significant increase in performance for v1.4.21 over v1.4.20:
Before*
```
PS> dotnet run -c Release --framework netcoreapp3.1
OSVersion: Microsoft Windows NT 6.2.9200.0
ProcessorCount: 16
ClockSpeed: 0 MHZ
Actor Count: 32
Messages sent/received per client: 200000 (2e5)
Is Server GC: True
Thread count: 109
Num clients, Total [msg], Msgs/sec, Total [ms]
1, 200000, 113379, 1764.56
5, 1000000, 186429, 5364.05
10, 2000000, 185340, 10791.11
15, 3000000, 183218, 16374.06
20, 4000000, 179824, 22244.63
25, 5000000, 182716, 27365.89
30, 6000000, 182039, 32960.61
```
After*
```
PS> dotnet run -c Release --framework netcoreapp3.1
OSVersion: Microsoft Windows NT 6.2.9200.0
ProcessorCount: 16
ClockSpeed: 0 MHZ
Actor Count: 32
Messages sent/received per client: 200000 (2e5)
Is Server GC: True
Thread count: 111
Num clients, Total [msg], Msgs/sec, Total [ms]
1, 200000, 109770, 1822.14
5, 1000000, 192902, 5184.79
10, 2000000, 191663, 10435.53
15, 3000000, 191339, 15679.11
20, 4000000, 192725, 20755.78
25, 5000000, 189754, 26350.14
30, 6000000, 189772, 31617.20
```
> N.B. these after numbers don't benefit from the performance benefits we observed in v1.4.20 when we invoked `ThreadPool.SetMinThreads(0,0)`, which makes them even more impressive.
Akka.DependencyInjection Updates**
We had one major issue we implemented in v1.4.21 for Akka.DependencyInjection: [Abstraction of `ServiceProvider`, Improving Akka.DependencyInjection ](https://github.com/akkadotnet/akka.net/pull/4814)
What this change did was:
Deprecate the `Akka.DependencyInjection.ServiceProvider` class in favor of the `Akka.DependencyInjection.DependencyResolver` class - to avoid namespace collision with Microsoft.Extensions.DependencyInjection.ServiceProvider;
Deprecates the `Akka.DependencyInjection.ServiceProviderSetup` class in favor of the `Akka.DependencyInjection.DependencyResolverSetup` class for consistency reasons;
`Akka.DependencyInjection.DependencyResolver` now takes an input of type [`IDependencyResolver`](https://getakka.net/api/Akka.DependencyInjection.IDependencyResolver.html), which allows users to abstract away the `IServiceProvider` and mock / replace it during unit testing; and
Added some non-generic `Props` methods for dynamically spawning actors via DI.
All of these changes are backwards-compatible with v1.4.20 and earlier - and the deprecation warnings will appear in your code when you upgrade. If you run into any [issues upgrading to Akka.DependencyInjection v1.4.21 please reply on this thread](https://github.com/akkadotnet/akka.net/discussions/5070)!
Other Changes and Fixes**
[Akka.Streams: A couple of fixes affecting the `FileSubscriber`](https://github.com/akkadotnet/akka.net/pull/5035)
[Akka.DistributedData: memory leak when recovering events from LMDB data store](https://github.com/akkadotnet/akka.net/issues/5022)
[Akka.DistributedData: port `VectorClock` performance optimizations to `VersionVector` and similar types](https://github.com/akkadotnet/akka.net/issues/4956)
To see the [full set of fixes in Akka.NET v1.4.21, please see the milestone on Github](https://github.com/akkadotnet/akka.net/milestone/51).
| COMMITS | LOC+ | LOC- | AUTHOR |
| --- | --- | --- | --- |
| 12 | 999 | 160 | Aaron Stannard |
| 10 | 410 | 299 | Gregorius Soedharmo |
| 4 | 853 | 520 | Ismael Hamed |
| 4 | 5 | 5 | dependabot[bot] |
| 1 | 6 | 2 | Brah McDude |
| 1 | 428 | 67 | Sam Ember |
| 1 | 1 | 1 | Martin |