UmbralSocket.Net
1.2.0
dotnet add package UmbralSocket.Net --version 1.2.0
NuGet\Install-Package UmbralSocket.Net -Version 1.2.0
<PackageReference Include="UmbralSocket.Net" Version="1.2.0" />
<PackageVersion Include="UmbralSocket.Net" Version="1.2.0" />
<PackageReference Include="UmbralSocket.Net" />
paket add UmbralSocket.Net --version 1.2.0
#r "nuget: UmbralSocket.Net, 1.2.0"
#:package UmbralSocket.Net@1.2.0
#addin nuget:?package=UmbralSocket.Net&version=1.2.0
#tool nuget:?package=UmbralSocket.Net&version=1.2.0
UmbralSocket.Net
Uma biblioteca binária de comunicação ultraleve e de altíssimo desempenho via Unix Sockets ou Named Pipes para backends .NET 9 AOT. Inspirada em umbral-socket do Rust.
Exemplo rápido
using System.Buffers;
using System.Text;
using UmbralSocket.Net.Unix;
var server = new UnixUmbralSocketServer();
server.RegisterHandler(0x01, payload =>
{
// Converter ReadOnlySequence<byte> para string
var text = Encoding.UTF8.GetString(UmbralSocket.Net.SequenceExtensions.ToArray(payload));
return ValueTask.FromResult(Encoding.UTF8.GetBytes($"SAVE:{text}"));
});
var cts = new CancellationTokenSource();
_ = server.StartAsync(cts.Token);
var client = new UnixUmbralSocketClient();
var response = await client.SendAsync(0x01, Encoding.UTF8.GetBytes("hello"));
Console.WriteLine(Encoding.UTF8.GetString(response)); // SAVE:hello
cts.Cancel();
🚀 Exemplos completos
Confira os projetos de exemplo completos em samples/
que demonstram:
- ✅ Unix Sockets e Named Pipes
- ✅ Múltiplos handlers por opcode
- ✅ Serialização JSON com AOT
- ✅ Benchmarks de performance
- ✅ Diferentes cenários de uso
- ✅ Cross-platform compatibility
🎮 Executar os exemplos
cd samples/UmbralSocket.Net.Sample
# Modo interativo (menu)
dotnet run
# Demos específicos
dotnet run unix # Unix Socket demo (Linux/macOS/Windows 10+)
dotnet run namedpipe # Named Pipe demo (Windows)
dotnet run benchmark # Performance benchmark
dotnet run json # JSON serialization demo
dotnet run server # Ping-pong: sobe apenas o servidor
dotnet run client # Ping-pong: sobe apenas o cliente
🏓 Exemplo ping-pong (client/server)
O exemplo ping-pong demonstra comunicação bidirecional real entre dois processos (ou containers):
🐳 Rodando o exemplo ping-pong com Docker Compose (WSL/Linux)
Você pode testar o ping-pong client/server facilmente usando Docker Compose no WSL ou Linux:
# Na raiz do projeto
docker compose up --build
Isso irá:
- Fazer o build automático do projeto (NativeAOT) dentro do container
- Subir dois serviços: um como server e outro como client
- Exibir no terminal o ping-pong acontecendo entre os dois containers
Para reiniciar do zero (limpar imagens/volumes):
docker compose down -v
docker system prune -af --volumes
O exemplo está pronto para ambientes Linux/WSL2, sem necessidade de dependências locais além do Docker.
📋 Ver detalhes completos: SAMPLES.md
Licença
Este projeto está licenciado sob a Licença MIT.
Atribuição
Este projeto foi inspirado pelo umbral-socket de alan-venv, que está licenciado sob as licenças Apache-2.0 e MIT. Embora esta seja uma implementação independente para .NET, reconhecemos a inspiração e o design conceitual do projeto original em Rust.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 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. |
-
net9.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
v1.2.0: Exemplo ping-pong client/server para Docker Compose, build multi-stage com NativeAOT, suporte total a .NET 9, melhorias de compatibilidade Linux, documentação e exemplos revisados. Veja CHANGELOG.md para detalhes.