Akka.Serialization.TestKit 1.4.47-beta

Prefix Reserved
This is a prerelease version of Akka.Serialization.TestKit.
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Akka.Serialization.TestKit --version 1.4.47-beta
                    
NuGet\Install-Package Akka.Serialization.TestKit -Version 1.4.47-beta
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Akka.Serialization.TestKit" Version="1.4.47-beta" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Akka.Serialization.TestKit" Version="1.4.47-beta" />
                    
Directory.Packages.props
<PackageReference Include="Akka.Serialization.TestKit" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Akka.Serialization.TestKit --version 1.4.47-beta
                    
#r "nuget: Akka.Serialization.TestKit, 1.4.47-beta"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Akka.Serialization.TestKit@1.4.47-beta
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Akka.Serialization.TestKit&version=1.4.47-beta&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Akka.Serialization.TestKit&version=1.4.47-beta&prerelease
                    
Install as a Cake Tool

Akka.NET

Akka.NET logo

Gitter

Akka.NET is a .NET port of the popular Akka project from the Scala / Java community. We are an idiomatic .NET implementation of the actor model built on top of the .NET Common Language Runtime.

Akka.NET is a .NET Foundation project.

.NET Foundation Logo

How is Akka.NET Used?

Akka.NET can be used in-process or inside large, distributed real-time systems; we support a wide variety of use cases.

Akka.NET can be used to solve the following types of problems:

  1. Concurrency - Akka.NET actors only process messages one-at-a-time and they do so in first in, first out (FIFO) order; this means that any application state internal to an actor is automatically thread-safe without having to use locks or any other shared-memory synchronization mechanisms.
  2. Stream Processing - Akka.NET actors and Akka.Streams make it easy to build streaming applications, used for processing incoming streams of data or incoming streams of live events such as UI or network events inside native applications.
  3. Event-Driven Programming - actors make it easy to build event-driven applications, as actors' message-processing routines naturally express these types of designs.
  4. Event Sourcing and CQRS - Akka.Persistence, used by actors to make their state re-entrant and recoverable across restarts or migrations between nodes, natively supports event sourcing. Akka.Persistence.Query can be used to compute CQRS-style projections and materialized views from Akka.Persistence data.
  5. Location Transparency - Akka.Remote makes it simple for actors in remote processes to transparently communicate with each other.
  6. Highly Available, Fault-Tolerant Distributed Systems - Akka.Cluster, Akka.Cluster.Sharding, and other tools built on top of Akka.Cluster make it possible to build highly available and fault-tolerant distributed systems by leveraging peer-to-peer programming models with topology-aware message routing and distribution.
  7. Low Latency, High Throughput - Akka.NET aims to be low latency and high throughput, processing 10s millions of messages per second in-memory and hundreds of thousands of messages per second over remote connections.

Where Can I Learn Akka.NET?

You can start by taking the Akka.NET Bootcamp, but there are many other great learning resources for Akka.NET Online.

Build Status

Stage Status
Build Build Status
NuGet Pack Build Status
.NET Framework Unit Tests Build Status
.NET Framework MultiNode Tests Build Status
.NET Core (Windows) Unit Tests Build Status
.NET Core (Linux) Unit Tests Build Status
.NET Core (Windows) MultiNode Tests Build Status
.NET Core (Linux) MultiNode Tests
Docs Build Status

Install Akka.NET via NuGet

If you want to include Akka.NET in your project, you can install it directly from NuGet

To install Akka.NET Distributed Actor Framework, run the following command in the Package Manager Console

PM> Install-Package Akka
PM> Install-Package Akka.Remote

And if you need F# support:

PM> Install-Package Akka.FSharp

Builds

Please see Building Akka.NET.

To access nightly Akka.NET builds, please see the instructions here.

Support

If you need help getting started with Akka.NET, there's a number of great community resources online:

If you and your company are interested in getting professional Akka.NET support, you can contact Petabridge for dedicated Akka.NET support.

Product 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 is compatible.  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.  net10.0 was computed.  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 netcoreapp3.1 is compatible. 
.NET Framework net471 is compatible.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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.5.46-beta 109 7/17/2025
1.5.45-beta 117 7/7/2025
1.5.44-beta 118 6/19/2025
1.5.43-beta 267 6/10/2025
1.5.42-beta 122 5/21/2025
1.5.41-beta 124 5/6/2025
1.5.40-beta 442 3/24/2025
1.5.39-beta 82 3/14/2025
1.5.38-beta 75 2/17/2025
1.5.37-beta 65 1/23/2025
1.5.36-beta 64 1/22/2025
1.5.35-beta 61 1/13/2025
1.5.34-beta 63 1/7/2025
1.5.33-beta 67 12/23/2024
1.5.32-beta 67 12/4/2024
1.5.31-beta 73 11/11/2024
1.5.30-beta 74 10/3/2024
1.5.29-beta 73 10/1/2024
1.5.28-beta1 84 8/23/2024
1.5.28-beta 77 9/4/2024
1.5.27.1-beta 82 7/26/2024
1.5.27-beta2 86 7/3/2024
1.5.27-beta1 73 7/3/2024
1.5.27-beta 74 7/25/2024
1.5.26-beta 77 6/27/2024
1.5.25-beta 77 6/14/2024
1.5.24-beta 81 6/7/2024
1.5.23-beta 80 6/6/2024
1.5.22-beta 73 6/3/2024
1.5.21-beta 81 5/28/2024
1.5.20-beta 82 4/29/2024
1.5.19-beta 84 4/15/2024
1.5.18-beta 79 3/12/2024
1.5.17.1-beta 78 3/2/2024
1.5.17-beta 84 2/29/2024
1.5.16-beta 95 1/29/2024
1.5.15-beta 104 1/10/2024
1.5.14-beta 173 11/3/2023
1.5.13-beta1 128 8/25/2023
1.5.13-beta 94 9/18/2023
1.5.12-beta 155 8/2/2023
1.5.11-beta 145 7/27/2023
1.5.10-beta 145 7/25/2023
1.5.9-beta 142 7/17/2023
1.5.8-beta 142 6/15/2023
1.5.7-beta 122 5/17/2023
1.5.6-beta 126 5/8/2023
1.5.5-beta 128 5/4/2023
1.5.4-beta 128 4/25/2023
1.5.3-beta 133 4/20/2023
1.5.2-beta 131 4/6/2023
1.5.1-beta 137 3/15/2023
1.5.0-beta6 143 3/1/2023
1.5.0-beta5 143 3/1/2023
1.5.0-beta4 146 2/28/2023
1.5.0-beta3 144 2/27/2023
1.5.0-beta2 154 2/23/2023
1.5.0-beta1 146 2/20/2023
1.5.0-beta 142 3/2/2023
1.5.0-alpha4 157 2/1/2023
1.5.0-alpha3 155 11/15/2022
1.5.0-alpha2 155 10/17/2022
1.5.0-alpha1 177 8/22/2022
1.4.51-beta 133 6/28/2023
1.4.50-beta 139 3/15/2023
1.4.49-beta1 159 1/11/2023
1.4.49-beta 163 1/27/2023
1.4.48-beta 153 1/5/2023
1.4.47-beta 135 12/9/2022
1.4.46-beta 148 11/15/2022
1.4.45-beta 183 10/19/2022
1.4.44-beta 166 10/17/2022
1.4.43-beta 158 9/27/2022
1.4.42-beta 178 9/23/2022
1.4.41-beta 164 8/31/2022
1.4.40-beta 160 7/22/2022
1.4.39-beta 192 6/1/2022
1.4.38-beta 202 5/6/2022
1.4.37-beta 194 4/14/2022
1.4.36-beta 189 4/5/2022
1.4.35-beta 195 3/18/2022
1.4.34-beta 196 3/7/2022
1.4.33-beta 197 2/14/2022
1.4.32-beta 209 1/18/2022
1.4.31-beta 208 12/21/2021
1.4.30-beta 216 12/20/2021
1.4.29-beta 212 12/13/2021
1.4.28-beta 238 11/10/2021
1.4.27-beta 243 10/11/2021
1.4.26-beta 209 9/28/2021
1.4.25-beta 279 9/8/2021
1.4.24-beta 236 8/17/2021
1.4.23-beta 240 8/10/2021
1.4.22-beta 263 8/5/2021
1.4.21-beta1 239 6/4/2021
1.4.21-beta 263 6/16/2021
1.4.20-beta 249 5/12/2021
1.4.19-beta 229 4/28/2021
1.4.18-beta 239 3/23/2021
1.4.17-beta 255 3/10/2021
1.4.16-beta 268 1/22/2021
1.4.15-beta 276 1/20/2021
1.4.14-beta 268 12/30/2020
1.4.13-beta 325 12/16/2020
1.4.12-beta 306 11/16/2020
1.4.11-beta 372 11/5/2020
1.4.10-beta 381 8/20/2020
1.4.9-beta 445 7/21/2020
1.4.8-beta 460 6/17/2020
1.4.7-beta 418 5/27/2020
1.4.6-beta 418 5/12/2020
1.4.5-beta 432 4/29/2020
1.4.4-beta 416 3/31/2020
1.4.3-beta 427 3/18/2020
1.4.2-beta 454 3/13/2020
1.4.1-rc3 442 3/10/2020
1.4.1-rc2 403 3/10/2020
1.4.1-rc1 424 2/28/2020
1.4.1-beta 405 3/11/2020
1.4.0-beta4 473 1/28/2020
1.4.0-beta3 486 10/30/2019
1.4.0-beta2 456 9/23/2019
1.4.0-beta1 467 7/19/2019
1.4.0-beta 462 10/30/2019
1.3.19-beta 40 5/2/2024
1.3.18-beta 414 3/9/2020
1.3.17-beta 450 12/20/2019
1.3.16-beta 439 11/14/2019
1.3.15-beta 450 9/23/2019
1.3.14-beta 479 7/30/2019
1.3.13-beta 533 4/30/2019
1.3.12-beta 507 3/14/2019
1.3.11-beta 579 12/18/2018
1.3.10-beta 681 11/2/2018
1.3.9-beta 706 8/23/2018
1.3.8-beta 1,008 6/5/2018
1.3.7-beta 1,070 5/15/2018
1.3.6-beta 1,033 4/17/2018
1.3.5-beta 889 2/22/2018
1.3.4-beta 1,048 2/1/2018
1.3.3-beta 1,061 1/19/2018
1.3.2-beta 883 10/21/2017
1.3.1-beta 903 9/5/2017
1.3.0-beta 920 8/11/2017

Akka.NET v1.4.47 is a maintenance patch for Akka.NET v1.4.46 that includes a variety of bug fixes, performance improvements, and new features.
Actor Telemetry**
Starting in Akka.NET v1.4.47 local and remotely deployed actors will now emit events when being started, stopped, and restarted:
```csharp
public interface IActorTelemetryEvent : INoSerializationVerificationNeeded, INotInfluenceReceiveTimeout
{
/// <summary>
/// The actor who emitted this event.
/// </summary>
IActorRef Subject {get;}
/// <summary>
/// The implementation type for this actor.
/// </summary>
Type ActorType { get; }
}
/// <summary>
/// Event emitted when actor starts.
/// </summary>
public sealed class ActorStarted : IActorTelemetryEvent
{
public IActorRef Subject { get; }
public Type ActorType { get; }
}
/// <summary>
/// Event emitted when actor shuts down.
/// </summary>
public sealed class ActorStopped : IActorTelemetryEvent
{
public IActorRef Subject { get; }
public Type ActorType { get; }
}
/// <summary>
/// Emitted when an actor restarts.
/// </summary>
public sealed class ActorRestarted : IActorTelemetryEvent
{
public IActorRef Subject { get; }
public Type ActorType { get; }
public Exception Reason { get; }
}
```
These events will be consumed from popular Akka.NET observability and management tools such as [Phobos](https://phobos.petabridge.com/) and [Petabridge.Cmd](https://cmd.petabridge.com/) to help provide users with more accurate insights into actor workloads over time, but you can also consume these events yourself by subscribing to them via the `EventStream`:
```csharp
// subscribe to all actor telemetry events
Context.System.EventStream.Subscribe(Self, typeof(IActorTelemetryEvent));
```
By default actor telemetry is disabled** - to enable it you'll need to turn it on via the following HOCON setting:
```hocon
akka.actor.telemetry.enabled = on
```
The performance impact of enabling telemetry is negligible, as you can [see via our benchmarks](https://github.com/akkadotnet/akka.net/pull/6294#issuecomment-1340251897).
Fixes and Updates**
[Akka.Streams: Fixed `System.NotSupportedException` when disposing stage with materialized `IAsyncEnumerable`](https://github.com/akkadotnet/akka.net/issues/6280)
[Akka.Streams: `ReuseLatest` stage to repeatedly emit the most recent value until a newer one is pushed](https://github.com/akkadotnet/akka.net/pull/6262)
[Akka.Remote: eliminate `ActorPath.ToSerializationFormat` UID allocations](https://github.com/akkadotnet/akka.net/pull/6195) - should provide a noticeable Akka.Remote performance improvement.
[Akka.Remote: Remoting and an exception as a payload message ](https://github.com/akkadotnet/akka.net/issues/3903) - `Exception` types are now serialized properly inside `Status.Failure` messages over the wire. `Status.Failure` and `Status.Success` messages are now managed by Protobuf - so you might see some deserialization errors while upgrading if those types are being exchanged over the wire.
[Akka.TestKit: `TestActorRef` can not catch exceptions on asynchronous methods](https://github.com/akkadotnet/akka.net/issues/6265)
You can see the [full set of tracked issues for Akka.NET v1.4.47 here](https://github.com/akkadotnet/akka.net/issues?q=is:closed+milestone:1.4.47).
| COMMITS | LOC+ | LOC- | AUTHOR |
| --- | --- | --- | --- |
| 10 | 2027 | 188 | Aaron Stannard |
| 1 | 157 | 10 | Gregorius Soedharmo |