目录
回到顶部一、简介
简单解析一下gRPC,gRPC 是一个由Google开源的,跨语言的,高性能的远程过程调用(RPC)框架。
特点:
- 跨语言
- 内容protobuf格式(比json体积小),网络传输快
- 使用HTTP/2进行传输
适合高性能轻量的微服务,一般对外的接口用restful api,内部服务的调用用gRPC。gRPC是一个分布式服务框架,和以前的WebService,WCF类似。
回到顶部二、创建gRPC服务端
1.创建gRPC项目
新建一个gRPC模板的项目
特别的地方就这里4点。
1.基于http2来通信。
2.proto协议文件,greet.proto是项目默认给我们的一个hello world的示例。它会根据协议自动生成必要的类。
3.服务类,Greeter.GreeterBase来自于2中的proto文件自动生成的类,生成的类在\obj\Debug\net6.0\Protos 目录下。
自动生成的类:
4.Program.cs添加了gRPC服务,和把GreeterService注册到管道中。
2.编写自己的服务
怎么样写自己的调用服务呢?
1.创建proto文件
参照上面的示例创建自己的Proto文件
代码:
- syntax = "proto3";
- option csharp_namespace = "GrpcDemo.Service";
- package order;
- // 订单服务定义
- service Order {
- // 创建订单
- rpc CreateOrder (CreateRequest) returns (CreateResult);
- //查询订单
- rpc QueryOrder (QueryRequest) returns (QueryResult);
- }
- //创建订单请求参数
- message CreateRequest {
- string orderNo = 1;
- string orderName=2;
- double price=3;
- }
- //创建订单返回结果
- message CreateResult {
- bool result = 1;
- string message=2;
- }
- //查询订单请求参数
- message QueryRequest{
- string id=1;
- }
- //查询订单返回结果
- message QueryResult{
- string id=1;
- string orderNo=2;
- string orderName=3;
- double price=4;
- }
复制代码
生成一下就能看到对应的类已经生成了。
data:image/s3,"s3://crabby-images/88cab/88cab90deb31e669e806fc93faef1a5eded513df" alt=""
2.实现界说的服务
创建OrderService.cs
- public class OrderService:Order.OrderBase
- {
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />private readonly ILogger<GreeterService> _logger;
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public OrderService(ILogger<GreeterService> logger)
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> _logger = logger;
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <summary>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// 创建订单
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// </summary>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <param name="request"></param>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <param name="context"></param>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <returns></returns>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public override Task<CreateResult> CreateOrder(CreateRequest request, ServerCallContext context)
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //报存数据库 todo
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> return Task.FromResult(new CreateResult
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> {
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Result=true,
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Message="订单创建成功"
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> });
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <summary>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// 查询订单
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// </summary>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <param name="request"></param>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <param name="context"></param>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <returns></returns>
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public override Task<QueryResult> QueryOrder(QueryRequest request, ServerCallContext context)
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //查询数据库 //todo
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> return Task.FromResult(new QueryResult
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> {
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Id = request.Id,
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderNo = DateTime.Now.ToString("yyyyMMddHHmmss"),
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderName = "冰箱",
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Price = 1288
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> });
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}
- }
复制代码 继承的Order.OrderBase 是上面的proto文件生成的,然后实现了proto里面界说的两个服务。
然后在program.cs里面把服务注入管道。
data:image/s3,"s3://crabby-images/8cde4/8cde41c9ae87f34853fd062c1bdef12fc507e382" alt=""
到这里服务端就完成了,就可以启动服务端了。
data:image/s3,"s3://crabby-images/dcb49/dcb49e312273292d1f4cb290f72650a6e62fe682" alt=""
浏览器访问不了,要通过gRPC客户端才气访问,下面就建一个gRPC客户端。
回到顶部三、创建gRPC客户端
1.创建客户端项目
1.1、这里创建一个控制台程序。
1.2、然后添加Nuget包- Google.Protobuf
- Grpc.Net.Client
- Grpc.Tools<br>Grpc.Net.clientFactory
复制代码 1.3、把服务端的proto文件拷贝过来
1.4、编辑项目文件,把proto里面的内容替换掉,默认是服务端的配置
- <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />
复制代码 生成的时候,客户端也生成了对应proto的类
2.grPC服务https的调用
由于服务端提供了http和https的端口,这里先调用https的
创建GrpcRequestTest.cs类
- /// /// gRPC请求测试 /// public class GrpcRequestTest { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public void CreateOrder() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //常规使用,https <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> string url = "https://localhost:7246"; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> using(var channel=GrpcChannel.ForAddress(url)) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />var client = new Order.OrderClient(channel); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />var reply = client.CreateOrder(new CreateRequest() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"), <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderName = "冰箱22款", <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Price = 1688 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Console.WriteLine($"结果:{reply.Result},message:{reply.Message}"); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> } <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Console.ReadKey(); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} }
复制代码 结果:
data:image/s3,"s3://crabby-images/5168b/5168b26f6858174b72a1f759f64f2a863f73518e" alt=""
3.gRPC内网http调用
- public void CreateOrder() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //使用http <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> string url = "http://localhost:5246"; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> using(var channel=GrpcChannel.ForAddress(url)) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />var client = new Order.OrderClient(channel); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />var reply = client.CreateOrder(new CreateRequest() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"), <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderName = "冰箱22款", <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Price = 1688 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Console.WriteLine($"结果:{reply.Result},message:{reply.Message}"); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> } <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Console.ReadKey(); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />}
复制代码 比起https,前面多了一行。结果:
data:image/s3,"s3://crabby-images/861e1/861e13d07b1bf7d76492119bcee2091983df869a" alt=""
4.IOC注入的方式调用gRPC
4.1、program.cs里面注入gRPCClient
- // See https://aka.ms/new-console-template for more information
- using GrpcDemo.Client;
- using GrpcDemo.Service;
- using Microsoft.Extensions.DependencyInjection;
- Console.WriteLine("Hello, World!");
- IServiceCollection services = new ServiceCollection();
- services.AddTransient<GrpcRequestTest>();
- #region gRPC Client注册
- AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);
- services.AddGrpcClient<Order.OrderClient>(options =>
- {
- options.Address = new Uri("http://localhost:5246");
- }).ConfigureChannel(grpcOptions =>
- {
- //可以完成各种配置,比如token
- });
- #endregion
- //构建容器
- IServiceProvider serviceProvider = services.BuildServiceProvider();
- //解析grpc请求测试
- var grpcRequestTest = serviceProvider.GetService<GrpcRequestTest>();
- //执行
- grpcRequestTest.CreateOrder();
复制代码 grpcRequestTest里代码:
- /// /// gRPC请求测试 /// public class GrpcRequestTest { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />private Order.OrderClient _orderClient; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public GrpcRequestTest(Order.OrderClient orderClient) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> _orderClient = orderClient; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public void CreateOrder() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> var reply = _orderClient.CreateOrder(new CreateRequest() <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"), <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />OrderName = "冰箱22款", <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Price = 1688 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> }); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Console.WriteLine($"结果:{reply.Result},message:{reply.Message}"); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Console.ReadKey(); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} }
复制代码 结果:
data:image/s3,"s3://crabby-images/94516/9451637bde73d4f91d009e60689f79809dd4670c" alt=""
回到顶部四、webapi中加入gRPC
通常我们的服务有对外提供对外接口,又要对内提供gRPC服务,那怎么做呢,下面在webapi中加入gRPC服务
1.创建asp.net core mvc项目
2.安装nuget包3.添加protebuf文件
把上面的proto文件复制过来
data:image/s3,"s3://crabby-images/e7127/e7127896f2a7be2f96b2e73045a2f0f08024bf5b" alt=""
4.添加Service
data:image/s3,"s3://crabby-images/fa50a/fa50a42803bc68a00d8f2a9871c6fc03d11de886" alt=""
- public class OrderService : Order.OrderBase { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />private readonly ILogger _logger; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />public OrderService(ILogger logger) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> _logger = logger; <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// 创建订单 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> public override Task CreateOrder(CreateRequest request, ServerCallContext context) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //报存数据库 todo <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> return Task.FromResult(new CreateResult <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Result = true, <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />Message = "订单创建成功" <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> }); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// 查询订单 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />/// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> /// <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> public override Task QueryOrder(QueryRequest request, ServerCallContext context) <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> //查询数据库 //todo <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> return Task.FromResult(new QueryResult <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> { <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />OrderInfo = new OrderInfo <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />{ <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Id = request.Id, <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderNo = DateTime.Now.ToString("yyyyMMddHHmmss"), <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> OrderName = "冰箱", <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> Price = 1288 <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" /> }); <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
- <Protobuf Include="Protos\order.proto" GrpcServices="Client" />} }
复制代码 5.注册gRPC服务
在Program.cs文件中
data:image/s3,"s3://crabby-images/80f4c/80f4c9ecd4ff2d83ad463a665b60d23bf87081d9" alt=""
到这里,就把gRPC加入到webapi里面了。
6.验证
启动asp.net core mvc程序
data:image/s3,"s3://crabby-images/464d2/464d2d9acb94dc96aeb51798c82e8f286cb545c5" alt=""
浏览器能访问,证明 restful api是没问题的。
然后再用上面的客户端访问一下gRPC的服务。
data:image/s3,"s3://crabby-images/58d0d/58d0d8c726f4303f7af2dbc085e266b4712be8fe" alt=""
结果:data:image/s3,"s3://crabby-images/488a5/488a5e673ff33ecb073ececb825d9343333cf2d9" alt=""
这样就成功对外提供api接口和对内提供gRPC服务了。
源码地址:https://github.com/weixiaolong325/GrpcDemo.Service
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |