PersistedConcurrentSortedList.IFileSystem
10.0.101
dotnet add package PersistedConcurrentSortedList.IFileSystem --version 10.0.101
NuGet\Install-Package PersistedConcurrentSortedList.IFileSystem -Version 10.0.101
<PackageReference Include="PersistedConcurrentSortedList.IFileSystem" Version="10.0.101" />
<PackageVersion Include="PersistedConcurrentSortedList.IFileSystem" Version="10.0.101" />
<PackageReference Include="PersistedConcurrentSortedList.IFileSystem" />
paket add PersistedConcurrentSortedList.IFileSystem --version 10.0.101
#r "nuget: PersistedConcurrentSortedList.IFileSystem, 10.0.101"
#:package PersistedConcurrentSortedList.IFileSystem@10.0.101
#addin nuget:?package=PersistedConcurrentSortedList.IFileSystem&version=10.0.101
#tool nuget:?package=PersistedConcurrentSortedList.IFileSystem&version=10.0.101
Akka.WebSocket
Akka.WebSocket is a tiny bridge that wires a running Akka.NET actor system to a Suave WebSocket endpoint. It targets both net9.0 and netstandard2.0, so the same package works for .NET 9 applications and legacy .NET Framework hosts.
The library exposes a single entry point: start Suave, hand it an ActorSystem plus the actor that should receive WebSocket JSON/text payloads, and the bridge will keep forwarding messages asynchronously. It also provides a REST-style health check that round-trips through your actor, so downstream load balancers can observe the same infrastructure used by WebSocket clients.
Features
- Actor-first design – no
Ask/blocking calls; messages areTelled to the supplied actor. - Health probe support –
/healthsends"healthcheck"to the handler actor and returns its response. - Multi-target build – ships as a single package for
net9.0andnetstandard2.0. - Graceful shutdown – disposing the returned
ServerHandlestops Suave and cancels the WebSocket loop. - Explicit licensing – ships under MIT while clearly documenting bundled Apache‑licensed dependencies (Suave 2.5.6 and Akka.NET 1.5.54).
Getting Started
Install the package from NuGet (package id pending):
dotnet add package Akka.WebSocket
Create an actor that understands your payloads (and optionally the "healthcheck" message) and start the bridge:
open System
open Akka.Actor
open Akka.WebSocketBridge
type EchoActor() =
inherit UntypedActor()
override _.OnReceive msg =
match msg with
| :? string as text when text = "healthcheck" ->
base.Sender.Tell("ok", base.Self)
| :? string as text ->
printfn "client said: %s" text
| _ -> ()
let system = ActorSystem.Create("WebSocketCluster")
let echo = system.ActorOf(Props.Create<EchoActor>(), "ws-echo")
let server =
WebSocketServer.start
system
"ws"
None
(Choice2Of2 ("0.0.0.0", 8080))
(fun _ -> Some echo)
printfn "Listening on ws://0.0.0.0:8080/ws"
Console.ReadLine() |> ignore
server.Stop()
system.Terminate() |> Async.AwaitTask |> Async.RunSynchronously
Connect with any WebSocket client (browser, PowerShell, wscat, etc.) and send UTF-8 text frames; they appear in your actor. Pings are answered automatically, and fragmented/binary frames close the connection.
Demo Host
The repository contains Program.fs, a sample console host that starts:
- an Akka.NET cluster seed node (defaults:
127.0.0.1:4053), - a single
EchoActor, and - the WebSocket bridge bound to
ws://0.0.0.0:8080/ws.
Run it with:
dotnet run -f net9.0 --project akka.websocket.fsproj \
-- 0.0.0.0 8080 127.0.0.1 4053 "akka.tcp://WebSocketCluster@127.0.0.1:4053"
Arguments (all optional):
| Position | Meaning | Default |
|---|---|---|
| 0 | HTTP bind address | 0.0.0.0 |
| 1 | HTTP port | 8080 |
| 2 | Cluster hostname | 127.0.0.1 |
| 3 | Cluster port | 4053 |
| 4 | Seed node list | self address |
Health Check
The demo actor replies "ok" to "healthcheck". The /health endpoint calls into that actor, so you can verify end-to-end readiness:
curl http://localhost:8080/health
# => ok
If the actor is unavailable or throws, the endpoint returns an HTTP 500 with the failure message.
Building and Packing
Restore and build:
dotnet restore
dotnet build
Create a NuGet package (produces both target frameworks):
dotnet pack -c Release -o nupkgs
Publish the resulting .nupkg to NuGet with your preferred workflow (dotnet nuget push, GitHub Actions, etc.).
License
This project is licensed under the terms of the included LICENSE file (MIT).
Suave 2.5.6 and Akka.NET 1.5.54 are distributed under the Apache License 2.0; see THIRD-PARTY-NOTICES.md for details and required notices.
| 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. 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 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
- FAkka.Fsi.Contracts (>= 10.0.101.1)
- FSharp.Compiler.Service (>= 43.10.101)
- FSharp.Core (>= 10.0.101)
- PersistedConcurrentSortedList (>= 10.0.101)
-
net10.0
- FAkka.Fsi.Contracts (>= 10.0.101.1)
- FSharp.Compiler.Service (>= 43.10.101)
- FSharp.Core (>= 10.0.101)
- PersistedConcurrentSortedList (>= 10.0.101)
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 |
|---|---|---|
| 10.0.101 | 0 | 12/25/2025 |