我正在使用 proto 文件试验 gRPC 服务和客户端。建议是在 .NET Core ( https://docs.microsoft.com/en-us/aspnet/core/grpc/clientfactory?view=aspnetcore-3.1 ) 中使用 gRPC 客户端工厂集成。为此,您需要注册从 Grpc.Tools 包生成的 Grpc.Core.ClientBase 派生的客户端,如下所示:
Host.CreateDefaultBuilder(args)
.ConfigureServices((hostContext, services) =>
{
services.AddGrpcClient<MyGrpcClientType>(o =>
{
o.Address = new Uri("https://localhost:5001");
});
})
我的理解是 MyGrpcClientType 被 DI 注册为一个临时客户端,这意味着每次注入时都会创建一个新的,但是客户端与 HttpClientFactory 集成在一起,允许重用通道而不是每次都创建。
现在,我想使用 protobuf-net.grpc 从接口生成客户端,看起来是这样完成的:
GrpcClientFactory.AllowUnencryptedHttp2 = true;
using var http = GrpcChannel.ForAddress("http://localhost:10042");
var calculator = http.CreateGrpcService<ICalculator>();
如果我正确地认为创建通道的成本很高,但客户端很便宜,那么如何使用 protobuf-net.grpc 实现与 HttpClientFactory 的集成(以及底层通道的重用)?上面似乎每次我想要一个客户端时都会创建一个 GrpcChannel ,那么重用通道的正确方法是什么?
同样,是否可以在 ASP.Net Core 中使用以下代码注册 protobuf-net.grpc 生成的服务类?
endpoints.MapGrpcService<MyGrpcServiceType>();
(请纠正以上任何误解)