文章6 | 阅读 3136 | 点赞0
gRPC 是一个由Google开源的,跨语言的,高性能的远程过程调用(RPC)框架。 gRPC使客户端和服务端应用程序可以透明地进行通信,并简化了连接系统的构建。它使用HTTP/2作为通信协议,使用 Protocol Buffers 作为序列化协议。
它的主要优点:
这些优点使gRPC非常适合:
不建议使用gRPC的场景:
支持的语言如下:
gRPC 现在可以非常简单的在 .NET Core 和 ASP.NET Core 中使用,在 .NET Core 上的实现的开源地址:https://github.com/grpc/grpc-dotnet ,它目前由微软官方 ASP.NET 项目的人员进行维护,良好的接入 .NET Core 生态。
.NET Core 的 gRPC 功能如下:
通过 Visual Studio 2019 (16.3.0)提供的模板,可以快速创建 gRPC 服务。
来扒拉一下默认源码包含了什么东东。
① 配置文件 appsettings.json ,多了Kestrel 启用 HTTP/2 的配置,因为 gRPC 是基于 HTTP/2 来通信的
② PB协议文件 greet.proto 用于自动生成服务、客户端和消息(表示传递的数据)的C# Class
③ 服务类 GreeterService ,服务类集成的 Greeter.GreeterBase 来自于根据proto文件自动生成的,生成的类在 obj\Debug\netcoreapp3.0目录下
自动生成的类:
④ Startup.cs类,将 gRPC服务添加到了终结点路由中
⑤ csproj 项目文件,包含了 proto 文件引用
2.运行
这是因为HTTP/2需要HTTPS,尽管HTTP/2协议没有明确规定需要HTTPS,但是为了安全在浏览器实现上都要求了HTTPS,所以现在的HTTP/2和HTTPS基本都是一对。
1.添加一个.NET Core 控制台应用程序
2.通过nuget添加包:Grpc.Net.Client、Google.Protobuf、Grpc.Tools
客户端csproj文件
<ItemGroup>
<PackageReference Include="Google.Protobuf" Version="3.13.0" />
<PackageReference Include="Grpc.Net.Client" Version="2.32.0" />
<PackageReference Include="Grpc.Tools" Version="2.33.1">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
</ItemGroup>
3.将服务的 proto 文件复制到客户端
4.编辑客户端csproj文件,添加关于proto文件的描述
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>netcoreapp3.1</TargetFramework>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Google.Protobuf" Version="3.13.0" />
<PackageReference Include="Grpc.Net.Client" Version="2.32.0" />
<PackageReference Include="Grpc.Tools" Version="2.33.1">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
</ItemGroup>
<ItemGroup>
<Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
</ItemGroup>
</Project>
注意 GrpcServices=“Client” 这里是Client和服务是不一样的
5.生成客户端项目可以通过proto文件生成类
6.添加客户端调用代码
static async Task Main(string[] args)
{
var channel = GrpcChannel.ForAddress("https://localhost:5001");
var client = new Greeter.GreeterClient(channel);
var reply = await client.SayHelloAsync(
new HelloRequest { Name = "我是客户端" });
Console.WriteLine("Greeter 服务返回数据: " + reply.Message);
Console.ReadKey();
}
7.先启动服务,然后运行客户端
这里可以看到,客户端成功调用了服务,收到了返回的消息。
前面我们使用的 Greeter 服务是由模板自动给我们创建的,现在我们来自己动手写一个服务。
编写一个“撸猫服务”
1.定义 proto 文件 LuCat.proto,并在csproj项目文件中添加描述
syntax = "proto3";
option csharp_namespace = "AspNetCoregRpcService";
import "google/protobuf/empty.proto";
package LuCat; //定义包名
//定义服务
service LuCat{
//定义吸猫方法
rpc SuckingCat(google.protobuf.Empty) returns(SuckingCatResult);
}
message SuckingCatResult{
string message=1;
}
2.实现服务 LuCatService.cs
public class LuCatService:LuCat.LuCatBase
{
private static readonly List<string> Cats=new List<string>(){"英短银渐层","英短金渐层","美短","蓝猫","狸花猫","橘猫"};
private static readonly Random Rand=new Random(DateTime.Now.Millisecond);
public override Task<SuckingCatResult> SuckingCat(Empty request, ServerCallContext context)
{
return Task.FromResult(new SuckingCatResult()
{
Message = $"您吸了一只{Cats[Rand.Next(0, Cats.Count)]}"
});
}
}
3.在 Startup终结点路由中注册
endpoints.MapGrpcService<LuCatService>();
4.添加客户端调用
var catClient = new LuCat.LuCatClient(channel);
var catReply = await catClient.SuckingCatAsync(new Empty());
Console.WriteLine("调用撸猫服务:"+ catReply.Message);
5.运行测试
技巧1
上面章节的操作步骤中,我们需要在服务和客户端之间复制proto,这是一个可以省略掉的步骤。
1.复制 Protos 文件夹到解决方案根目录(sln文件所在目录)
2.删除客户端和服务项目中的 Protos 文件夹
3.在客户端项目文件csproj中添加关于proto文件的描述
<ItemGroup>
<Protobuf Include="..\..\Protos\greet.proto" GrpcServices="Client" Link="Protos\greet.proto" />
</ItemGroup>
4.在服务项目文件csproj中添加关于proto文件的描述
<ItemGroup>
<Protobuf Include="..\..\Protos\greet.proto" GrpcServices="Server" Link="Protos\greet.proto" />
</ItemGroup>
在实际项目中,请自己计算相对路径
5.这样两个项目都是使用的一个proto文件,只用维护这一个文件即可
技巧2
我们在实际项目中使用,肯定有多个 proto 文件,难道我们每添加一个 proto 文件都要去更新 csproj文件?
我们可以使用MSBuild变量来帮我们完成,我们将 csproj 项目文件中引入proto文件信息进行修改。
服务端:
<ItemGroup>
<Protobuf Include="..\..\Protos\*.proto" GrpcServices="Server" Link="Protos\%(RecursiveDir)%(Filename)%(Extension)" />
</ItemGroup>
客户端:
<ItemGroup>
<Protobuf Include="..\..\Protos\*.proto" GrpcServices="Client" Link="Protos\%(RecursiveDir)%(Filename)%(Extension)" />
</ItemGroup>
示例:
gRPC 现目前是一款非常成熟的高性能RPC框架,当前的生态是非常好的,很多公司的产品或者开源项目都有在使用gRPC,有了它,相信可以让我们更容易的构建.NET Core 微服务,可以让 .NET Core 更好的接入 gRPC 生态。不得不说这是 .NET Core 3.1 带来的最令人振奋的特性之一。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://codeboy.blog.csdn.net/article/details/109253557
内容来源于网络,如有侵权,请联系作者删除!