【ASP.NET Core學習】遠程過程調用 - gRPC使用

来源:https://www.cnblogs.com/WilsonPan/archive/2019/12/24/12000796.html
-Advertisement-
Play Games

【ASP.NET Core學習】 介紹在gRPC使用,將從從(What)什麼是RPC,(When)什麼時候需要使用RPC,(How)如何使用gRPC。 RPC是Remote Procedure Call簡稱,翻譯過來是遠程過程調用。它是一個進程間的通訊技術,基於Client-Server模式,讓程... ...


 本文介紹在gRPC使用,將從下麵幾個方面介紹

  1. 什麼是RPC
  2. 什麼時候需要RPC
  3. 如何使用gRPC

什麼是RPC

RPC是Remote Procedure Call簡稱,翻譯過來是遠程過程調用。它是一個進程間的通訊技術,基於Client-Server模式,讓程式像調用本地方法一樣使用,而無需去關係它細節如何實現。

上面是我的理解,怕理解有錯或者表達不准確,下麵引用維基百科

維基百科 a remote procedure call (RPC) is when a computer program causes a procedure (subroutine) to execute in a different address space (commonly on another computer on a shared network), which is coded as if it were a normal (local) procedure call, without the programmer explicitly coding the details for the remote interaction

網上找到一個圖,比較形象描述RPC調用過程

 

什麼時候需要RPC

RPC是解決進程間通訊(可以是同一個伺服器,也可以是不同伺服器的進程間,但是通常是內網的不同伺服器之間進程通訊)。 

解決進程間通信,Web Api也是可以解決,為什麼還需要RPC?我認為可以從下麵幾點

1. Web Api是基於HTTP,RPC可以是HTTP,也可以是TCP,甚至基於Socket,RPC框架通常都是隱藏通訊細節,讓我們無感知使用

2. Web Api 通常基於JSON格式,XML格式,這種格式易讀性強,但是隨之帶來就是傳輸過程需要把數據的元數據也帶進去傳輸

3. Web Api更多應用場景是提供方定義好介面,由客戶端按需調用,RPC通常需要調用方和提供方溝通一起定義介面

所以PRC更多是使用以下場景

  1. 對通訊性能要求較高
  2. 微服務
  3. 點到點通訊

gRPC使用

 gRPC是Google開源的高性能RPC框架,有以下幾個特點

  1. 現代高性能輕量級 RPC 框架。
  2. 協定優先 API 開發,預設使用protobuf,允許與語言無關的實現。(這裡涉及兩點,1.面向介面開發,依賴抽象而不是具體,2. 可以不同語言實現協作)

  3. 使用 Protobuf 二進位序列化減少對網路的使用。(減少網路傳輸)

  4. 可用於多種語言的工具,以生成強類型伺服器和客戶端。

  5. 支持客戶端、伺服器和雙向流式處理調用。

下麵開始介紹如何在Net Core上使用gRPC

 

一、安裝dotnet-gRPC工具(用於引用protobuf文件,生成客戶端/服務端代碼)

dotnet tool install dotnet-grpc -g

二、新建一個protobuf文件

syntax = "proto3";

option csharp_namespace = "gRPC.Services";

package sms;

// The greeting service definition.
service SmsSender {
  // Sends a greeting
  rpc SendSms (SmsRequest) returns (SmsResponse);
}

// The request message containing the user's name.
message SmsRequest {
  string tel = 1;
  string content = 2;
}

// The response message containing the greetings.
message SmsResponse {
  int32 code = 1;
  string message = 2;
}

三、新建一個服務端

1. 新建一個gRPC工程

dotnet new grpc -n gRPC.Services

2. 引入步驟二生成的protobuf文件(可以使用通配符引入多個protobuf文件)

dotnet-grpc add-file ..\gRPC.Protos\*.proto -s Serve

3. 新建服務類

public class SmsService : SmsSender.SmsSenderBase
{
    private readonly ILogger<SmsService> _logger;
    public SmsService(ILogger<SmsService> logger)
    {
        _logger = logger;
    }

    public override Task<SmsResponse> SendSms(SmsRequest request, ServerCallContext context)
    {
        return Task.FromResult(new SmsResponse
        {
            Code = 1,
            Message = "發送成功"
        });
    }
}
SmsSender 是生成工具生成的服務端代碼

4. 配置grpc服務類終結點

app.UseEndpoints(endpoints =>
{
    endpoints.MapGrpcService<SmsService>();
});

 

四、新建客戶端

 1. 新建控制台程式

dotnet new console -n gRPC.Client

2. 添加包(Google.Protobuf)

dotnet add package Google.Protobuf

3. 引入步驟二生成的protobuf文件(可以使用通配符引入多個protobuf文件),註意:這裡需要生成是客戶端代碼,當然也可以用Both參數生成

dotnet-grpc add-file ..\gRPC.Protos\*.proto -s Client

 

五、運行

1. 運行服務端

2. 啟動客戶端

客戶端輸出下麵信息

{"Code":1,"Message":"\u53D1\u9001\u6210\u529F"}

 

六、小結

gRPC的生命周期

Client(發送請求) -> Client stub(壓縮/解壓) -> Client RPC Transfer(發送/接收) -> Server RPC Transfer(接收/發送) -> Server stub(解壓/壓縮) -> Server (處理響應)

gPRC幫我們隱藏中間的環節,只剩下兩頭的代碼(俗稱業務邏輯代碼)

protobuf它是一種可序列化的數據結構,但它更重要是定義介面,讓服務端和客戶端能分離出來

轉發請標明出處:https://www.cnblogs.com/WilsonPan/p/12000796.html

示例代碼:https://github.com/WilsonPan/AspNetCoreExamples/tree/master/gRPC


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要和大家分享最詳細的linux安裝php過程,然後寫好了nginx的安裝配置,後面就是php的安裝和mysql的安裝,不過時間有限,而且放篇里也太長,所以都是分開來寫,php安裝完畢後就是mysql的配置了。 一:檢查是否安裝了php 1)yum安裝檢查:yum list已安裝| grep p ...
  • linux下部署php項目環境可以分為兩種,一種使用Apache,php,mysql的壓縮包安裝,一種用yum命令進行安裝。 使用三種軟體的壓縮包進行安裝,需要手動配置三者之間的關係。apache和php之間的配置沒有什麼難度,但是和mysql進行配置的時候就需要對php的瞭解了。 我的官方群點擊此 ...
  • 本篇文章給大家分享的內容是關於php redis 操作手冊,有著一定的參考價值,有需要的朋友可以參考一下 String 類型操作 1 string是redis最基本的類型,而且string類型是二進位安全的。意思是redis的string可以包含任何數據。 2 3 比如jpg圖片或者序列化的對象 4 ...
  • PHP高併發和大流量的解決方案 一 高併發的概念 在互聯網時代,併發,高併發通常是指併發訪問。也就是在某個時間點,有多少個訪問同時到來。 二 高併發架構相關概念 1、QPS (每秒查詢率) : 每秒鐘請求或者查詢的數量,在互聯網領域,指每秒響應請求數(指HTTP請求) 2、PV(Page View) ...
  • $GLOBALS——引用全局作用域中可用的全部變數。 $GLOBALS一個包含了全部變數的全局組合數組。變數的名字就是數組的鍵。(即所有出現過的全局變數,都可通過$GLOBALS獲取到) 在PHP中,定義在函數體外的全局變數,函數內部是不能直接獲取的,所以需要global聲明或者$GLOBALS[] ...
  • 1)set中每個元素的值都唯一,而且系統能根據元素的值自動進行排序。set中元素的值不能直接被改變 set具備的兩個特點: 1. set中的元素都是排序好的 2. set中的元素都是唯一的,沒有重覆的 2)聲明:例:set<int> s; 3)set的常用的方法 (s.~) begin(); // ...
  • 由於當前C++項目需要使用ajax庫去post調用ashx介面,介面地址如下所示: 需要傳遞的參數如下: 然後發現qml比較好調用ajax.js庫,所以本章通過C++界面去獲取qml方法來實現調用ashx介面(以一個C++界面demo程式為例) 1.抓post數據 通過網頁獲取到的post數據如下所 ...
  • 第八章 多態 多態的條件: 1. 要有繼承 2.父類對象引用子類對象 3. 要有方法的重寫 多態的作用:消除類型之間的耦合關係。 將一個方法調用與一個方法主體關聯起來稱作綁定。若在程式執行前進行綁定,叫做前期綁定;在運行時根據對象的類型進行綁定,叫做後期綁定,也叫動態綁定、運行時綁定。 Java中除 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...