.NET Core(.NET6)中gRPC使用

来源:https://www.cnblogs.com/lijiasnong/p/18047005
-Advertisement-
Play Games

目錄 一、簡介 二、創建gRPC服務端 1.創建gRPC項目 2.編寫自己的服務 三、創建gRPC客戶端 1.創建客戶端項目 2.grPC服務https的調用 3.gRPC內網http調用 4.IOC註入的方式調用gRPC 四、webapi中加入gRPC 回到頂部 一、簡介 簡單解析一下gRPC,g ...


目錄

 


回到頂部

一、簡介

簡單解析一下gRPC,gRPC 是一個由Google開源的,跨語言的,高性能的遠程過程調用(RPC)框架。

特點:

  • 跨語言
  • 內容protobuf格式(比json體積小),網路傳輸快
  • 使用HTTP/2進行傳輸

適合高性能輕量的微服務,一般對外的介面用restful api,內部服務的調用用gRPC。gRPC是一個分散式服務框架,和以前的WebService,WCF類似。

回到頂部

二、創建gRPC服務端

1.創建gRPC項目

新建一個gRPC模板的項目

 

 

 

 

 

 特別的地方就這裡4點。

1.基於http2來通信。

2.proto協議文件,greet.proto是項目預設給我們的一個hello world的示例。它會根據協議自動生成需要的類。

 

 

3.服務類,Greeter.GreeterBase來自於2中的proto文件自動生成的類,生成的類在\obj\Debug\net6.0\Protos 目錄下。

 

 自動生成的類:

 

 4.Program.cs添加了gRPC服務,和把GreeterService註冊到管道中。

2.編寫自己的服務

怎麼樣寫自己的調用服務呢?

 1.創建proto文件

參照上面的示例創建自己的Proto文件

 

 

 

 

 代碼:

複製代碼 複製代碼
syntax = "proto3";

option csharp_namespace = "GrpcDemo.Service";

package order;

// 訂單服務定義
service Order {
  // 創建訂單
  rpc CreateOrder (CreateRequest) returns (CreateResult);
  //查詢訂單
  rpc QueryOrder (QueryRequest) returns (QueryResult);
}

//創建訂單請求參數
message CreateRequest {
  string orderNo = 1;
  string orderName=2;
  double price=3;
}

//創建訂單返回結果
message CreateResult {
  bool result = 1;
  string message=2;
}

//查詢訂單請求參數
message QueryRequest{
    string id=1;
}
//查詢訂單返回結果
message QueryResult{
    string id=1;
    string orderNo=2;
    string orderName=3;
    double price=4;
}
複製代碼 複製代碼

 

生成一下就能看到對應的類已經生成了。

 

 2.實現定義的服務

 創建OrderService.cs

複製代碼 複製代碼
 public class OrderService:Order.OrderBase
    {
        private readonly ILogger<GreeterService> _logger;
        public OrderService(ILogger<GreeterService> logger)
        {
            _logger = logger;
        }
        /// <summary>
        /// 創建訂單
        /// </summary>
        /// <param name="request"></param>
        /// <param name="context"></param>
        /// <returns></returns>
        public override Task<CreateResult> CreateOrder(CreateRequest request, ServerCallContext context)
        {
            //報存資料庫 todo

            return Task.FromResult(new CreateResult
            {
                Result=true,
                Message="訂單創建成功"
            });
        }
        /// <summary>
        /// 查詢訂單
        /// </summary>
        /// <param name="request"></param>
        /// <param name="context"></param>
        /// <returns></returns>
        public override Task<QueryResult> QueryOrder(QueryRequest request, ServerCallContext context)
        {
            //查詢資料庫 //todo

            return Task.FromResult(new QueryResult
            {
                
                    Id = request.Id,
                    OrderNo = DateTime.Now.ToString("yyyyMMddHHmmss"),
                    OrderName = "冰箱",
                    Price = 1288
                
            });
        }
    }
複製代碼 複製代碼

繼承的Order.OrderBase 是上面的proto文件生成的,然後實現了proto裡面定義的兩個服務。

然後在program.cs裡面把服務註入管道。

 

 到這裡服務端就完成了,就可以啟動服務端了。

 

 瀏覽器訪問不了,要通過gRPC客戶端才能訪問,下麵就建一個gRPC客戶端。

回到頂部

三、創建gRPC客戶端

1.創建客戶端項目

1.1、這裡創建一個控制台程式。

1.2、然後添加Nuget包

Google.Protobuf
Grpc.Net.Client
Grpc.Tools
Grpc.Net.clientFactory

1.3、把服務端的proto文件拷貝過來

 

 1.4、編輯項目文件,把proto裡面的內容替換掉,預設是服務端的配置

 

 

  <Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
      <Protobuf Include="Protos\order.proto" GrpcServices="Client" />

生成的時候,客戶端也生成了對應proto的類

 

2.grPC服務https的調用

因為服務端提供了http和https的埠,這裡先調用https的

創建GrpcRequestTest.cs類

複製代碼 複製代碼
 /// <summary>
    /// gRPC請求測試
    /// </summary>
    public class GrpcRequestTest
    {
        public void CreateOrder()
        {
            //常規使用,https
            string url = "https://localhost:7246";
            using(var channel=GrpcChannel.ForAddress(url))
            {
                var client = new Order.OrderClient(channel);
                var reply = client.CreateOrder(new CreateRequest()
                {
                    OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"),
                    OrderName = "冰箱22款",
                    Price = 1688
                });

                Console.WriteLine($"結果:{reply.Result},message:{reply.Message}");
            }
            Console.ReadKey();
        }
    }
複製代碼 複製代碼

結果:

3.gRPC內網http調用

複製代碼 複製代碼
      public void CreateOrder()
        {
             //使用http
            AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);
            string url = "http://localhost:5246";

            using(var channel=GrpcChannel.ForAddress(url))
            {
                var client = new Order.OrderClient(channel);
                var reply = client.CreateOrder(new CreateRequest()
                {
                    OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"),
                    OrderName = "冰箱22款",
                    Price = 1688
                });

                Console.WriteLine($"結果:{reply.Result},message:{reply.Message}");
            }
            Console.ReadKey();
        }
複製代碼 複製代碼

比起https,前面多了一行。結果:

 

4.IOC註入的方式調用gRPC

4.1、program.cs裡面註入gRPCClient

複製代碼 複製代碼
// See https://aka.ms/new-console-template for more information
using GrpcDemo.Client;
using GrpcDemo.Service;
using Microsoft.Extensions.DependencyInjection;

Console.WriteLine("Hello, World!");

IServiceCollection services = new ServiceCollection();
services.AddTransient<GrpcRequestTest>();

#region gRPC Client註冊
AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);
services.AddGrpcClient<Order.OrderClient>(options =>
{
    options.Address = new Uri("http://localhost:5246");
}).ConfigureChannel(grpcOptions =>
{
    //可以完成各種配置,比如token
});
#endregion

//構建容器
IServiceProvider serviceProvider = services.BuildServiceProvider();
//解析grpc請求測試
var grpcRequestTest = serviceProvider.GetService<GrpcRequestTest>();
//執行
grpcRequestTest.CreateOrder();
複製代碼 複製代碼

grpcRequestTest里代碼:

複製代碼 複製代碼
/// <summary>
    /// gRPC請求測試
    /// </summary>
    public class GrpcRequestTest
    {
        private Order.OrderClient _orderClient;
        public GrpcRequestTest(Order.OrderClient orderClient)
        {
            _orderClient = orderClient;
        }
        public void CreateOrder()
        {
            var reply = _orderClient.CreateOrder(new CreateRequest()
            {
                OrderNo = DateTime.Now.ToString("yyyMMddHHmmss"),
                OrderName = "冰箱22款",
                Price = 1688
            });
            Console.WriteLine($"結果:{reply.Result},message:{reply.Message}");
            Console.ReadKey();
        }
    }
複製代碼 複製代碼

結果:

 

回到頂部

四、webapi中加入gRPC

通常我們的服務有對外提供對外介面,又要對內提供gRPC服務,那怎麼做呢,下麵在webapi中加入gRPC服務

1.創建asp.net core mvc項目

2.安裝nuget包

Grpc.AspNetCore

3.添加protebuf文件

把上面的proto文件複製過來

 

 

4.添加Service

 

 

複製代碼 複製代碼
  public class OrderService : Order.OrderBase
    {
        private readonly ILogger<OrderService> _logger;
        public OrderService(ILogger<OrderService> logger)
        {
            _logger = logger;
        }
        /// <summary>
        /// 創建訂單
        /// </summary>
        /// <param name="request"></param>
        /// <param name="context"></param>
        /// <returns></returns>
        public override Task<CreateResult> CreateOrder(CreateRequest request, ServerCallContext context)
        {
            //報存資料庫 todo

            return Task.FromResult(new CreateResult
            {
                Result = true,
                Message = "訂單創建成功"
            });
        }
        /// <summary>
        /// 查詢訂單
        /// </summary>
        /// <param name="request"></param>
        /// <param name="context"></param>
        /// <returns></returns>
        public override Task<QueryResult> QueryOrder(QueryRequest request, ServerCallContext context)
        {
            //查詢資料庫 //todo

            return Task.FromResult(new QueryResult
            {
                OrderInfo = new OrderInfo
                {
                    Id = request.Id,
                    OrderNo = DateTime.Now.ToString("yyyyMMddHHmmss"),
                    OrderName = "冰箱",
                    Price = 1288
                }
            });
        }
    }
複製代碼 複製代碼

5.註冊gRPC服務

在Program.cs文件中

 

到這裡,就把gRPC加入到webapi裡面了。 

6.驗證

啟動asp.net core mvc程式

 

 

 

瀏覽器能訪問,證明 restful api是沒問題的。

然後再用上面的客戶端訪問一下gRPC的服務。

 

 

 結果:

 

 這樣就成功對外提供api介面和對內提供gRPC服務了。

 

源碼地址:https://github.com/weixiaolong325/GrpcDemo.Service

 


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

-Advertisement-
Play Games
更多相關文章
  • 概述:該通用單例泛型基類使用C#實現,線程安全,通過泛型參數和Lazy<T>實現簡化的單例模式。優點包括線程安全、泛型通用性、簡化實現、以及延遲載入的特性。 優點: 線程安全: 使用Lazy<T>確保了線程安全的延遲初始化,避免了在多線程環境下可能導致的競態條件問題。 泛型通用性: 通過泛型參數,該 ...
  • 概述:以上內容詳細介紹了在 C# 中實現不改變原 List 值的多層嵌套複製方法,包括使用 AutoMapper、Json.NET、以及對象序列化的步驟和示例。這些方法提供了靈活而高效的方式,可以根據項目需求選擇最適合的深度複製方式。 1. 使用 AutoMapper 進行多層嵌套複製 AutoMa ...
  • AvaloniaUI是一個強大的跨平臺.NET客戶端開發框架,讓開發者能夠針對Windows、Linux、macOS、Android和iOS等多個平臺構建應用程式。在構建複雜的應用程式時,模塊化和組件間的通信變得尤為重要。Prism框架提供了模塊化的開發方式,支持插件的熱拔插,而MediatR則是一... ...
  • 概述:JSON Web Token(JWT)是一種用於安全傳輸信息的標準。主要用於身份驗證和信息傳遞,通過頭部、載荷和簽名構成。在.NET Core中,可通過Microsoft.AspNetCore.Authentication.JwtBearer實現後臺服務,提供生成、刷新和驗證Token的介面。 ...
  • NuGet下載Flurl FlurlHttpClient類 public class FlurlHttpClient { private readonly FlurlClient client; public FlurlHttpClient(FlurlClient client) { this.cl ...
  • 上一篇中,老周簡單膚淺地介紹了 XInput API 的使用,並模擬了滑鼠移動,左、右鍵單擊和滾輪。本篇,咱們用 .NET 代碼來完成相同的效果。 說起來也是倒霉,博文寫了一半,電腦忽然斷電了。不知道什麼原因,可能是 UPS 電源出故障。重新開機進來一看,博文沒有自動保存到草稿箱。我記得以前是有自動 ...
  • 通過本篇教程,我們學習瞭如何在 Taurus.MVC WebMVC 中使用部分視圖和頁面片段來提高代碼的復用性和可維護性。我們瞭解了部分視圖和頁面片段的基本概念,並學習瞭如何創建和使用它們。 ...
  • 已知在OpenXml有以下幾種超鏈接 功能 說明 跳轉頁面 跳轉某一頁:ppaction://hlinksldjump跳轉第一頁:ppaction://hlinkshowjump?jump=firstslide跳轉最後一頁:ppaction://hlinkshowjump?jump=lastslid ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...