gRPC是什么
gRPC是可以在任何情况中运行的今世开源高性能RPC框架。它可以通过可插拔的支持来有用地毗连数据中心内和跨数据中心的服务,以实现负载均衡,跟踪,运行状况查抄和身份验证。它也适用于分布式盘算的末了一英里,以将装备,移动应用步伐和欣赏器毗连到后端服务。
proto文件
用于界说gRPC服务和消息的协定;服务端和客户端共享proto文件。
利用新模板创建gRPC服务端
.NETcore 3.0创建项目提供了一个新的gRPC模板,可以轻松地利用ASP.NET Core构建gRPC服务。我们按照步调一步一步创建AA.GrpcService 服务,固然你可以利用命令:dotnet new grpc -o GrpcGreeter
选择gRPC服务项目模板
终极天生的项目
greet.proto文件
- syntax = "proto3";
- option csharp_namespace = "AA.GrpcService";
- package Greet;
- // The greeting service definition.
- service Greeter {
- // Sends a greeting
- rpc SayHello (HelloRequest) returns (HelloReply);
- }
- // The request message containing the user's name.
- message HelloRequest {
- string name = 1;
- }
- // The response message containing the greetings.
- message HelloReply {
- string message = 1;
- }
复制代码
GreeterService.cs
- public class GreeterService : Greeter.GreeterBase
- {
- private readonly ILogger<GreeterService> _logger;
- public GreeterService(ILogger<GreeterService> logger)
- {
- _logger = logger;
- }
- public override Task<HelloReply> SayHello(HelloRequest request, ServerCallContext context)
- {
- return Task.FromResult(new HelloReply
- {
- Message = "Hello " + request.Name
- });
- }
- }
复制代码
Startup.cs
- public void ConfigureServices(IServiceCollection services)
- {
- services.AddGrpc();
- }
- public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
- {
- if (env.IsDevelopment())
- {
- app.UseDeveloperExceptionPage();
- }
- app.UseRouting();
- app.UseEndpoints(endpoints =>
- {
- endpoints.MapGrpcService<GreeterService>();
- endpoints.MapGet("/", async context =>
- {
- await context.Response.WriteAsync("Communication with gRPC endpoints must be made through a gRPC client. To learn how to create a client, visit: https://go.microsoft.com/fwlink/?linkid=2086909");
- });
- });
- }
复制代码
创建完成之后,主动包罗了包的引用、proto文件的创建、services服务的天生,模板项目在配景执行一些操纵如
- 创建一个包罗全部gRPC依赖项的ASP.NET Core项目。
- 创建一个名为的gRPC服务界说文件greet.proto。
- 根据服务界说文件主动天生全部gRPC存根。
- GreeterService.cs根据主动天生的gRPC存根创建gRPC服务。
- 在Startup.cs中配置gRPC管道映射到GreeterService.cs
运行服务
创建gRPC客户端
下面,我们创建一个控制台应用步伐作为客户端调用gRPC服务;
引用gRPC服务,步调:右键项目添加=》服务引用弹出以下页面;
点击确定
我们看项目布局,他们会主动帮我们处理处罚一下操纵:
- package Grpc.Net.ClientFactory
- package Google.Protobuf
- package Grpc.Tools
- Protos 文件(包罗greet.proto)主动从AA.GrpcService项目拷贝
- 主动添加节点
- <ItemGroup>
- <Protobuf Include="..\AA.GrpcService\Protos\greet.proto" GrpcServices="Client">
- <Link>Protos\greet.proto</Link>
- </Protobuf>
- </ItemGroup>
复制代码
末了,添加以下代码举行gRPC哀求;
- class Program
- {
- static async Task Main(string[] args)
- {
- using var channel = GrpcChannel.ForAddress("https://localhost:5005");
- var client = new Greeter.GreeterClient(channel);
- var response = await client.SayHelloAsync(new HelloRequest { Name = "gRPC" });
- Console.WriteLine("Greeting:" + response.Message);
- Console.WriteLine("Press a key to exit");
- Console.ReadKey();
- }
- }
复制代码
运行结果图:
小结: .NETcore 3.0 使得利用gRPC黑白常方便集成到项目中,希望这篇文章使你可以了解.NETcore与gRPC结合利用。那gRPC适用于以了局景
-
微服务– gRPC专为低耽误和高吞吐量通信而计划。 gRPC对于效率至关告急的轻量级微服务非常有用。
-
点对点实时通信– gRPC对双向流具有出色的支持。 gRPC服务可以实时推送消息而无需轮询。
-
多种语言情况– gRPC工具支持全部流行的开发语言,因此gRPC是多语言情况的理想选择。
-
网络受限的情况– gRPC消息利用轻量级消息格式Protobuf举行了序列化。 gRPC消息始终小于等效的JSON消息。
参考:
- https://docs.microsoft.com/zh-cn/aspnet/core/grpc/?view=aspnetcore-3.0
- https://www.grpc.io/
- https://developers.google.com/protocol-buffers/docs/proto3
- https://www.cnblogs.com/stulzq/p/11581967.html
来源:https://www.cnblogs.com/chengtian/p/11714694.html |