ASP.NET Core 3.0使用gRPC的具體方法

 更新時間:2019年12月23日 14:41:34   作者:曉晨Master   我要評論
這篇文章主要介紹了ASP.NET Core 3.0使用gRPC,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一.簡介

gRPC 是一個由Google開源的,跨語言的,高性能的遠程過程調用(RPC)框架。 gRPC使客戶端和服務端應用程序可以透明地進行通信,并簡化了連接系統的構建。它使用HTTP/2作為通信協議,使用 Protocol Buffers 作為序列化協議。

它的主要優點:

  • 現代高性能輕量級 RPC 框架。
  • 約定優先的 API 開發,默認使用 Protocol Buffers 作為描述語言,允許與語言無關的實現。
  • 可用于多種語言的工具,以生成強類型的服務器和客戶端。
  • 支持客戶端,服務器雙向流調用。
  • 通過Protocol Buffers二進制序列化減少網絡使用。
  • 使用 HTTP/2 進行傳輸

這些優點使gRPC非常適合:

  • 高性能輕量級微服務 - gRPC設計為低延遲和高吞吐量通信,非常適合需要高性能的輕量級微服務。
  • 多語言混合開發 - gRPC工具支持所有流行的開發語言,使gRPC成為多語言開發環境的理想選擇。
  • 點對點實時通信 - gRPC對雙向流調用提供出色的支持。gRPC服務可以實時推送消息而無需輪詢。
  • 網絡受限環境 - 使用 Protocol Buffers二進制序列化消息,該序列化始終小于等效的JSON消息,對網絡帶寬需求比JSON小

不建議使用gRPC的場景:

  • 瀏覽器可訪問的API - 瀏覽器不完全支持gRPC。雖然gRPC-Web可以提供瀏覽器支持,但是它有局限性,引入了服務器代理
  • 廣播實時通信 - gRPC支持通過流進行實時通信,但不存在向已注冊連接廣播消息的概念
  • 進程間通信 - 進程必須承載HTTP/2才能接受傳入的gRPC調用,對于Windows,進程間通信管道是一種更快速的方法。

摘自微軟官方文檔

支持的語言如下:

二.gRPC on .NET Core

gRPC 現在可以非常簡單的在 .NET Core 和 ASP.NET Core 中使用,在 .NET Core 上的實現的開源地址:https://github.com/grpc/grpc-dotnet ,它目前由微軟官方 ASP.NET 項目的人員進行維護,良好的接入 .NET Core 生態。

.NET Core 的 gRPC 功能如下:

  • Grpc.AspNetCore 一個用于在ASP.NET Core承載gRPC服務的框架,將 gRPC和ASP.NET Core 功能集成在一起,如:日志、依賴注入、身份認證和授權。
  • Grpc.Net.Client 基于HttpClient (HttpClient現已支持HTTP/2)的 gRPC客戶端
  • Grpc.Net.ClientFactory 與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 帶來的最令人振奮的特性之一。

參考資料:

proto3 說明文檔

在ASP.NET Core中創建gRPC客戶端和服務

Demo 地址

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • asp.net音頻轉換之.amr轉.mp3(利用ffmpeg轉換法)

    asp.net音頻轉換之.amr轉.mp3(利用ffmpeg轉換法)

    AMR轉MP3可實現將手機上的AMR錄音轉換成流行的MP3格式,以適用更廣泛的應用。AMR的體積非常小,適用于存儲在手機中,當我們想將在手機上的音頻上傳到網絡,就需要將其轉換成MP3等流行的格式,本文就是介紹asp.net利用ffmpeg轉換法將.amr轉.mp3的方法,下面來一起看看吧。
    2016-12-12
  • asp.net Cookie操作類

    asp.net Cookie操作類

    Cookie操作類,本人得還很不錯哦。
    2009-12-12
  • js插件類庫組織與管理(基于asp.net管理)

    js插件類庫組織與管理(基于asp.net管理)

    在開發一個較大規模的網站,js插件類庫應用的是相當多。那么自然在一個頁面里就存在不少script和script相關的link標記,這樣js組織與管理自然成了一大問題。
    2010-07-07
  • c# .net 生成圖片驗證碼的代碼

    c# .net 生成圖片驗證碼的代碼

    c# .net 生成圖片驗證碼的代碼...
    2007-03-03
  • 分析10個ASP.NET控件最有用的屬性詳解

    分析10個ASP.NET控件最有用的屬性詳解

    對于微軟平臺開發人員而言,每天都要和各種ASP.NET控件打交道,本文不打算介紹各種控件的具體使用方法,相反,我只想和大家分享一下ASP.NET控件最有用的10個屬性,相信讀完本文可提升你的開發技能。
    2011-08-08
  • C#調用C++版本dll時的類型轉換需要注意的問題小結

    C#調用C++版本dll時的類型轉換需要注意的問題小結

    最近使用C#調用C++版本的dll遇到很多類型轉換的問題,現記錄出容易出錯的部分。
    2010-04-04
  • ASP.NET全棧開發教程之在MVC中使用服務端驗證的方法

    ASP.NET全棧開發教程之在MVC中使用服務端驗證的方法

    這篇文章主要給大家介紹了關于ASP.NET全棧開發教程之在MVC中使用服務端驗證的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-07-07
  • Asp.net MVC下使用Bundle合并、壓縮js與css文件詳解

    Asp.net MVC下使用Bundle合并、壓縮js與css文件詳解

    在web優化中有一種手段,壓縮js,css文件,減少文件大小,合并js,css文件減少請求次數。asp.net mvc中為我們提供一種使用c#代碼壓縮合并js和css這類靜態文件的方法。這篇文章主要介紹了在Asp.net MVC下使用Bundle合并、壓縮js與css文件的方法,需要的朋友可以參考下。
    2017-03-03
  • 基于Asp.Net MVC4 Bundle捆綁壓縮技術的介紹

    基于Asp.Net MVC4 Bundle捆綁壓縮技術的介紹

    本篇文章,小編將為大家介紹,Asp.Net MVC4 Bundle捆綁壓縮技術,有需要的朋友可以參考一下
    2013-04-04
  • asp.net+jquery Jsonp使用方法

    asp.net+jquery Jsonp使用方法

    Jsonp的用法非常簡單,不過需要服務器端和客戶端同時支持。
    2010-04-04

最新評論

pc蛋蛋幸运28app下载地址