第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如果可能,如何組織 proto 文件以重用消息?

如果可能,如何組織 proto 文件以重用消息?

Go
飲歌長嘯 2022-11-08 16:24:47
我最近開始在我的 golang 項目中使用 protobuf。我在下面創(chuàng)建了簡單的 protobuf 文件。我有三個不同的端點。GetLink接受CustomerRequest作為輸入?yún)?shù)并返回CustomerResponseGetBulkLinks接受BulkCustomerRequest作為輸入?yún)?shù)并返回BulkCustomerResponseStreaLinks接受StreamRequest作為輸入?yún)?shù)并返回CustomerResponse我想知道是否有任何方法可以改進原始文件下面的內(nèi)容,因為除了字段CustomerRequest之外BulkCustomerRequest幾乎所有內(nèi)容都相同resources,因此存在重復。輸入?yún)?shù)也是如此,StreamRequest因為它只clientId作為輸入?yún)?shù)。協(xié)議緩沖區(qū)中有什么可以重用其他消息類型的東西嗎?有沒有更好或更有效的方法來組織下面的原始文件,從而相應地重用消息?syntax = "proto3";option go_package = "github.com/david/customerclient/gen/go/data/v1";package data.v1;service CustomerService {  rpc GetLink(CustomerRequest) returns (CustomerResponse) {};  rpc GetBulkLinks(BulkCustomerRequest) returns (BulkCustomerResponse) {};  rpc StreaLinks(StreamRequest) returns (CustomerResponse) {};}message CustomerRequest {  int32 clientId = 1;  string resources = 2;  bool isProcess = 3;}message BulkCustomerRequest {  int32 clientId = 1;  repeated string resources = 2;  bool isProcess = 3;}message StreamRequest {  int32 clientId = 1;}message CustomerResponse {  string value = 1;  string info = 2;  string baseInfo = 3;  string link = 4;}message BulkCustomerResponse {  map<string, CustomerResponse> customerResponse = 1;}
查看完整描述

1 回答

?
蝴蝶刀刀

TA貢獻1801條經(jīng)驗 獲得超8個贊

協(xié)議緩沖區(qū)中有什么可以重用其他消息類型的東西嗎?

組成。

但是請記住,請求和響應負載可能會隨著時間而改變。即使他們今天看起來有共同點,但明天他們可能會分歧。畢竟它們在不同的 RPC 中使用。那么過度的耦合會達到相反的效果,變成技術債。

由于您的架構實際上每條消息不超過三個字段,因此我將保留所有內(nèi)容。無論如何,如果你真的必須,你可以考慮以下幾點:

  • 在單獨的消息中提取GetLinkGetBulkLinkscommon 字段并使用它進行編寫:

message CustomerRequestParams {

  int32 clientId = 1;

  bool isProcess = 2;

}


message CustomerRequest {

  CustomerRequestParams params = 1;

  string resources = 2;

}


message BulkCustomerRequest {

  CustomerRequestParams params = 1;

  repeated string resources = 2;

}

StreamRequest重復看起來就好了clientId??梢哉f,流在概念上與一元 RPC 不同,因此只需將它們分開即可。這只是一個領域。


查看完整回答
反對 回復 2022-11-08
  • 1 回答
  • 0 關注
  • 92 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號