Go gRPC環境安裝教程示例詳解

前言

gRPC 是一個高性能、開源和通用的 RPC 框架,面向移動和 HTTP/2 設計,帶來諸如雙向流、流控、頭部壓縮、單 TCP 連接上的多復用請求等特。這些特性使得其在移動設備上表現更好,更省電和節省空間占用。

在 gRPC 裡客戶端應用可以像調用本地對象一樣直接調用另一臺不同的機器上服務端應用的方法,使得您能夠更容易地創建分佈式應用和服務。

gRPC 默認使用 protocol buffers,這是 Google 開源的一套成熟的結構數據序列化機制,它的作用與 XML、json 類似,但它是二進制格式,性能好、效率高(缺點:可讀性差)。

安裝 protobuf

1.下載地址:https://github.com/protocolbuffers/protobuf/releases

根據自身電腦的操作系統,選擇最新的releases版本下載

2.解壓後在bin目錄找到protoc.exe,然後把它復制到GOBIN目錄下

一般操作是把protoc.exe所在的目錄配到環境變量裡,這裡直接把protoc.exe復制到GOBIN目錄下,前提是環境變量已經配置瞭GOBIN環境變量。

3.打開cmd,運行protoc –version

成功打印當前版本信息證明安裝成功瞭。

安裝相關包

安裝 golang 的proto工具包

go get -u github.com/golang/protobuf/proto

安裝 goalng 的proto編譯支持

go get -u github.com/golang/protobuf/protoc-gen-go

安裝 gRPC 包

go get -u google.golang.org/grpc

創建並編譯proto文件

1.新建proto文件夾,在裡面新建simple.proto文件

 syntax = "proto3";// 協議為proto3
package proto;
// 定義發送請求信息
message SimpleRequest{
    // 定義發送的參數
    // 參數類型 參數名 標識號(不可重復)
    string data = 1;
}
// 定義響應信息
message SimpleResponse{
    // 定義接收的參數
    // 參數類型 參數名 標識號(不可重復)
    int32 code = 1;
    string value = 2;
}
// 定義我們的服務(可定義多個服務,每個服務可定義多個接口)
service Simple{
    rpc Route (SimpleRequest) returns (SimpleResponse){};
}

2.編譯proto文件

cmd進入simple.proto所在目錄,運行以下指令進行編譯

protoc --go_out=plugins=grpc:./ ./simple.proto

VSCode-proto3插件介紹

使用VSCode的朋友看這裡,博主介紹一個VSCode插件,方便對編輯和編譯proto文件。

  • 擴展程序中搜索 VSCode-proto3,然後點擊安裝。
  • 在設置中找到setting.json文件,添加vscode-proto3插件配置
   // vscode-proto3插件配置
    "protoc": {
        // protoc.exe所在目錄
        "path": "C:\\Go\\bin\\protoc.exe",
        // 保存時自動編譯
        "compile_on_save": true,
        "options": [
            // go編譯輸出指令
            "--go_out=plugins=grpc:."
        ]
    }

每次編輯完proto文件後,隻需要保存,它就會自動幫助完成編譯。而且代碼有高亮顯示,代碼自動補全,代碼格式化等功能。

教程源碼地址:https://github.com/Bingjian-Zhu/go-grpc-example

以上就是Go gRPC環境安裝教程示例詳解的詳細內容,更多關於Go gRPC環境安裝教程的資料請關註WalkonNet其它相關文章!

推薦閱讀: