golang中如何使用GRPC

golang中如何使用GRPC,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

創(chuàng)新互聯(lián)專注于博州網(wǎng)站建設服務及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供博州營銷型網(wǎng)站建設,博州網(wǎng)站制作、博州網(wǎng)頁設計、博州網(wǎng)站官網(wǎng)定制、重慶小程序開發(fā)服務,打造博州網(wǎng)絡公司原創(chuàng)品牌,更為您提供博州網(wǎng)站排名全網(wǎng)營銷落地服務。

編寫proto中間文件

syntax="proto3";
package services;

message ProdRequest {
	int32 prod_id=1;
}

message ProdResponse {
	int32 prod_stock=1;

}

生成Prod.pb.go文件

進入proto文件所在目錄

protoc --go_out=../services Prod.proto

proto文件年增加rpc接口定義

syntax="proto3";
package services;

message ProdRequest {
	int32 prod_id=1;
}

message ProdResponse {
	int32 prod_stock=1;
}

service ProdService {
	rpc GetProdStock (ProdRequest) returns (ProdResponse);
}

生成rpc接口Prod.pb.go文件

protoc --go_out=plugins=grpc:../services Prod.proto

grpc-gateway

作用

對外部提供http方式訪問rpc服務

下載依賴

 go get -u github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway
 
 go get -u github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger

修改proto定義

syntax="proto3";
package services;
import "google/api/annotations.proto";

message ProdRequest {
	int32 prod_id=1;
}

message ProdResponse {
	int32 prod_stock=1;
}

service ProdService {
	rpc GetProdStock (ProdRequest) returns (ProdResponse){
		option (google.api.http) ={
			get: "/v1/prod/{prod_id}"
		};
	}
}

protoc生成gateway類

protoc --grpc-gateway_out=logtostderr=true:../services Prod.proto

關于golang中如何使用GRPC問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關知識。

分享標題:golang中如何使用GRPC
本文鏈接:http://bm7419.com/article48/igieep.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供建站公司、關鍵詞優(yōu)化、搜索引擎優(yōu)化、手機網(wǎng)站建設品牌網(wǎng)站制作、網(wǎng)站設計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設