Skip to content

Latest commit

 

History

History
39 lines (37 loc) · 1.26 KB

README.md

File metadata and controls

39 lines (37 loc) · 1.26 KB

BeetleX.Light.gpRPC

high performance dotnet core google protobuf rpc,supports millions of rps communication

server

RpcServer<ApplicationBase> server = new RpcServer<ApplicationBase>();
server.Options.SetDefaultListen(o =>
{
    o.Port = 8080;
});
server.RegisterMessages<RegisterReq>();
server.Options.AddLogOutputHandler<LogOutputToConsole>();
server.Options.LogLevel = LogLevel.Trace;
server.Start();
await Task.Delay(3000);

client

RpcClient client = "tcp://localhost:8080";
client.AddLogOutputHandler<LogOutputToConsole>();
client.RegisterMessages<RegisterReq>();
client.LogLevel = LogLevel.Trace;
IUserHandler handler = client.Create<IUserHandler>();
RegisterReq req = new RegisterReq();
req.Address = $"guangzhouLongdong";
req.City = $"guzngzhou";
req.Email = "[email protected]";
req.FirstName = $"fan";
req.LastName = $"henry";
req.Password = "122";
var resp = await handler.Register(req);

performance

Test hardware: 32-core cloud server, 100Gb network

1 connection 100 concurrency

image

20 connections 2000 concurrency

image