.Net?Core微服務(wù)rpc框架GRPC通信實際運(yùn)用
序
上一篇博客把grpc的概念說了個大概,介紹了proto的數(shù)據(jù)類型,基本語法,也寫了個小demo,是不是沒那么難?
今天要從理論到實際,寫兩個微服務(wù),并利用grpc完成兩者之間的通信。只是作為demo寫的話會十分簡單,畢竟理解為主。
服務(wù)端
首先要拿出之前寫好的proto文件,然后修改兩個屬性:
Build Action => Protobuf compiler gRpc Stub Classes => Server only
如圖:

當(dāng)然也可以在項目文件里看到它:

然后重新生成項目 ,會自動根據(jù)proto文件生成server端的文件。
引用
經(jīng)過剛才,已經(jīng)生成了對應(yīng)的服務(wù),我們可以直接在代碼里調(diào)用。
這是之前寫好的proto:
syntax = "proto3";
option csharp_namespace = "gRPCApiDemo.Protos";
package Demo;
service MyMath{
rpc MathAdd (AddRequest) returns (AddRespones) {}
}
message AddRequest{
int32 a=1;
int32 b=2;
}
message AddRespones{
int32 a=1;
}生成以后,會有一個MyMath.MyMathBase這個類,我們來繼承一下:

注意看命名空間,這是剛才項目生成以后根據(jù)proto生成的。
現(xiàn)在來重寫一下里面的方法(下圖是生成,也可以手動寫):

根據(jù)proto文件可知:
AddRequest包含兩個int參數(shù):A、B
AddRespones包含一個名為A的int參數(shù)
那我們把AB相加然后返回:
using Grpc.Core;
using gRPCApiDemo.Protos;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace gRPCApiDemo.Grpc
{
public class GrpcServiceMath : MyMath.MyMathBase
{
public override Task<AddRespones> MathAdd(AddRequest request, ServerCallContext context)
{
var respones = new AddRespones
{
A = request.A + request.B
};
return Task.FromResult(respones);
}
}
}再然后進(jìn)入StartUp設(shè)置一下:
app.UseHttpsRedirection();
app.UseEndpoints(endpoints =>
{
endpoints.MapGrpcService<MathServices>();
});服務(wù)端到這里就寫完了。
如果寫了更多service,那就需要在這里聲明更多的實現(xiàn)類;而且https是必須的。
客戶端
我準(zhǔn)備了一個空白項目。接下來你可以把之前服務(wù)端的proto文件拷貝過來,或者選擇重新寫一份,然后修改屬性以后生成一下項目:

其實還有一個選項是Client and Server,一次生成客戶端和服務(wù)端。
接下來注入靈魂:
services.AddGrpcClient<MyMath.MyMathClient>(o => o.Address = new Uri("https://localhost:5001"));MyMath是proto里聲明的服務(wù),MyMathClient是剛才生成的,里面的Uri是服務(wù)端所在的域名。
因為gRpc是基于http/2,而想要以http/2訪問有個比較麻煩的證書要搞,如果不想搞證書可以接著添加這一行:
AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);當(dāng)然,別忘了下面https的設(shè)置。
再接著我們新建一個controller,直接調(diào)用方法:
public class IndexController : Controller
{
private readonly MyMath.MyMathClient _client;
public IndexController(MyMath.MyMathClient client)
{
this._client = client;
}
public async Task<int> Add(int a, int b)
{
var respones = await _client.MathAddAsync(new AddRequest()
{
A = a,
B = b
});
return respones.A;
}
}MyMathClient就和MyMathBase一樣,也是自動生成的。而且現(xiàn)在這個版本會自動生成rpc調(diào)用的異步版本,就像代碼里的MathAddAsync。
我們跑一下看看:

完美。
源碼地址
最后小小的提醒一下,server和client端必須要有https,不然的話:

希望對初入微服務(wù)的同學(xué)有所幫助。
最后附上源碼:
https://gitee.com/muchengqingxin/GrpcServerDemo.git
https://gitee.com/muchengqingxin/GrpcClientDemo.git
到此這篇關(guān)于.Net Core微服務(wù)rpc框架GRPC通信實際運(yùn)用的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用grpcui測試ASP.NET core的gRPC服務(wù)
- .NET?Core(.NET6)中g(shù)RPC使用實踐
- .Net?Core微服務(wù)rpc框架GRPC通信基礎(chǔ)
- 在?ASP.NET?Core?中為?gRPC?服務(wù)添加全局異常處理
- 如何在.NET Core中為gRPC服務(wù)設(shè)計消息文件(Proto)
- .Net Core中使用Grpc的方法
- ASP.NET Core 3.0 gRPC攔截器的使用
- ASP.NET Core 3.0使用gRPC的具體方法
- 圖析ASP.NET Core引入gRPC服務(wù)模板
- ASP.NET Core中Grpc通信的簡單用法
相關(guān)文章
.Net結(jié)構(gòu)型設(shè)計模式之享元模式(Flyweight)
這篇文章介紹了.Net結(jié)構(gòu)型設(shè)計模式之享元模式(Flyweight),文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
.NET?6全新配置對象ConfigurationManager介紹
這篇文章介紹了.NET?6全新配置對象ConfigurationManager,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11
ASP.NET中MultiView和View選項卡控件的使用方法
ASP.NET中的MultiView和View控件可以作為承載其他控件的容器,一般我們都很少使用,本文主要介紹使用MultiView和View實現(xiàn)選項卡效果。2016-04-04

