热血高校1高清下载,菊花的诗句,猪猪手机书
一.简介
grpc 是一个由google开源的,跨语言的,高性能的远程过程调用(rpc)框架。 grpc使客户端和服务端应用程序可以透明地进行通信,并简化了连接系统的构建。它使用http/2作为通信协议,使用 protocol buffers 作为序列化协议。
它的主要优点:
这些优点使grpc非常适合:
不建议使用grpc的场景:
摘自
支持的语言如下:
二.grpc on .net core
grpc 现在可以非常简单的在 .net core 和 asp.net core 中使用,在 .net core 上的实现的开源地址: ,它目前由微软官方 asp.net 项目的人员进行维护,良好的接入 .net core 生态。
.net core 的 grpc 功能如下:
httpclientfactory
,允许对grpc客户端进行集中配置,并使用di注入到应用程序中三.使用 asp.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基本都是一对。
四. 创建 grpc 客户端
1.添加一个.net core 控制台应用程序
2.通过nuget添加包:grpc.net.client、google.protobuf、grpc.tools
3.将服务的 proto 文件复制到客户端
4.编辑客户端项目文件,添加关于proto文件的描述
<itemgroup> <protobuf include="protos\greet.proto" grpcservices="client" /> </itemgroup>
注意 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.0 带来的最令人振奋的特性之一。
参考资料:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Blazor server side 自家的一些开源的, 实用型项目的进度之 CEF客户端
.NET IoC模式依赖反转(DIP)、控制反转(Ioc)、依赖注入(DI)
vue+.netcore可支持业务代码扩展的开发框架 VOL.Vue 2.0版本发布
网友评论