.Net Core中使用Grpc的方法
一、Grpc概述
gRPC 基于如下思想:定義一個服務, 指定其可以被遠程調用的方法及其參數(shù)和返回類型。gRPC 默認使用protocol buffers作為接口定義語言,來描述服務接口和有效載荷消息結構。如果有需要的話,可以使用其他替代方案。
定義的服務分為4中類型:
- 單項 RPC,即客戶端發(fā)送一個請求給服務端,從服務端獲取一個應答,就像一次普通的函數(shù)調用。這種最常用。
- 服務端流式 RPC,即客戶端發(fā)送一個請求給服務端,可獲取一個數(shù)據(jù)流用來讀取一系列消息??蛻舳藦姆祷氐臄?shù)據(jù)流里一直讀取直到?jīng)]有更多消息為止。
- 客戶端流式 RPC,即客戶端用提供的一個數(shù)據(jù)流寫入并發(fā)送一系列消息給服務端。一旦客戶端完成消息寫入,就等待服務端讀取這些消息并返回應答。
- 雙向流式 RPC,即兩邊都可以分別通過一個讀寫數(shù)據(jù)流來發(fā)送一系列消息。這兩個數(shù)據(jù)流操作是相互獨立的,所以客戶端和服務端能按其希望的任意順序讀寫,例如:服務端可以在寫應答前等待所有的客戶端消息,或者它可以先讀一個消息再寫一個消息,或者是讀寫相結合的其他方式。每個數(shù)據(jù)流里消息的順序會被保持。
二、.Net Core中使用Grpc
使用Grpc 就三步:定義Grpc服務、實現(xiàn)Grpc服務、調用Grpc服務。
2.1 定義Grpc服務
1、在VS中選擇.Net Core創(chuàng)建類庫
2、引入Google.Protobuf、Grpc.Core包
3、創(chuàng)建proto文件,定義一個SsmServer服務,服務中提供兩個方法,一個最簡單的單項RPC方法,一個雙向流式RPC。后面這個文件會生成一個同名的C#類文件。
syntax = "proto3"; //語法指定proto3 package ShenDa.SSM.Grpc; //后面生成C#文件的命名空間 import "Protos/Common.proto"; import "Protos/Health.proto"; import "Protos/User.proto";//指定定義服務中使用的參數(shù)的位置 service SsmService{ //健康檢查 單項 RPC rpc Health(EmptyRequest) returns (HealthResponse){} //雙向流 rpc User_Add(stream UserAddRequest) returns(stream UserAddResponse){} }
定義的Health.proto文件
syntax = "proto3"; package ShenDa.SSM.Grpc; message HealthResponse{ //返回參數(shù) bool Success=1; //每個字段必須要指定序號 string Message=2; }
以上服務就定義完成了?,F(xiàn)在需要將這個proto文件生成C#文件,可以使用命令,也可以使用工具。在這里我使用工具生成。
5、引用Grpc.Tools ,然后在工程文件中指定要生成的proto文件。
<ItemGroup> <Protobuf Include="Protos\User.proto" /> <Protobuf Include="Protos\Health.proto" /> <Protobuf Include="Protos\Common.proto" /> <Protobuf Include="Protos\SsmService.proto" /> </ItemGroup>
生成項目,就會在 obj文件夾中生成對應的C#文件。其他文件都是生成對應的實體類,但是定義的服務的proto文件,比較特殊,它會生成一個同名的類文件,類中包含
- 一個抽象類,名稱為服務名+Base。其中包含我們定義的虛兩個方法
- 一個部分類,名稱為服務名+Client,繼承ClientBase<服務名Client>
以上所有的Grpc服務都已經(jīng)定義完了。因為客戶端不可能每個都通過添加應用項目的方式使用,所以我們還需要打包客戶端Nuget包。
6、生成Nuget包,提供給客戶端使用
通過VS設置打包生成Nuget包,生成Grpc客戶端Nuget包。
2.2 實現(xiàn)Grpc服務
通過VS的GRPC模板創(chuàng)建項目,定義實現(xiàn)類并繼承上面生成的抽象類,然后重寫我們定義的方法。
public partial class SsmServiceImpl : SsmService.SsmServiceBase { public override async Task<HealthResponse> Health(EmptyRequest request, ServerCallContext context) { var response = new HealthResponse() { Message = string.Empty, Success = true }; return await Task.FromResult(response); } }
配置Grpc服務
public void ConfigureServices(IServiceCollection services) { services.AddGrpc(); } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseEndpoints(endpoints => { endpoints.MapGrpcService<SsmServiceImpl>();//注入服務的實現(xiàn)。 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"); }); }); }
項目結構截圖:
2.3 客戶端調用Grpc
1、添加引用Google.Protobuf、Grpc.Core、Grpc.Net.Client 還有剛才生成的Nuget包ShenDa.SSM.Grpc
2、調用
class Program { static async Task Main(string[] args) { var channel = GrpcChannel.ForAddress("https://localhost:5001"); var client = new SsmServiceClient(channel); await HealthCheck(client); } public static async Task HealthCheck(SsmServiceClient client) { var response = await client.HealthAsync(new EmptyRequest()); System.Console.WriteLine(response.Success ? "健康" : "連接失敗"); } }
總結
到此這篇關于.Net Core中使用Grpc的方法的文章就介紹到這了,更多相關.Net Core使用Grpc內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
asp.net中日歷函數(shù)Calendar的使用方法
calendar 控件用于在瀏覽器中顯示日歷,該控件可顯示某個月的日歷,允許用戶選擇日期,也可以跳到前一個或下一個月2011-05-05使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作
這兩天在用Flex DataGrid做點東西,走了不少彎路,現(xiàn)將心得分享一下。2009-02-02將Access數(shù)據(jù)庫中數(shù)據(jù)導入到SQL Server中的詳細方法實例
將Access數(shù)據(jù)庫中數(shù)據(jù)導入到SQL Server中的詳細方法實例,需要的朋友可以參考一下2013-03-03asp.net 中將表單提交到另一頁 Code-Behind(代碼和html在不同的頁面)
To send Server control values from a different Web Forms page2009-04-04ASP.NET MVC SSO單點登錄設計與實現(xiàn)代碼
本篇文章主要介紹了ASP.NET MVC SSO單點登錄設計與實現(xiàn),具有一定的參考價值,有興趣的可以了解一下。2017-01-01如何在ASP.NET Core中使用ViewComponent
這篇文章主要介紹了如何在ASP.NET Core中使用ViewComponent,幫助大家更好的理解和學習使用.net技術,感興趣的朋友可以了解下2021-04-04