Kitex Server SDK化

2022-04-27 09:50 更新

Server SDK化

SDK化(invoker)允許用戶將 Kitex server 當作一個本地 SDK 調(diào)用。

調(diào)用通過 ?message ?完成,初始化 ?message ?需要 ?local ?和 ?remote ?兩個 ?net.Addr? ,分別表示本地地址和遠端(客戶端)地址(此處的地址主要用于日志監(jiān)控),初始化后通過 ?SetRequestBytes(buf []byte) error? 設置請求的二進制數(shù)據(jù)。最后調(diào)用 ?invoker ?的 ?Call ?方法即可完成調(diào)用。調(diào)用完成后可通過 ?message ?的 ?GetResponseBytes() ([]byte, error)? 獲取響應的二進制數(shù)據(jù)。

import (
		...
    "github.com/cloudwego/kitex/sdk/message"
  	...
)

func main() {
    var reqPayload, respPayload []byte
    var local, remote net.Addr
    ...
    // init local/remote
    ...
    ivk := echo.NewInvoker(new(EchoImpl))
    msg := message.NewMessage(local, remote)
    // 裝載payload
    msg.SetRequestBytes(reqPayload)
    // 發(fā)起調(diào)用
    err := ivk.Call(msg)
    if err != nil {
        ...
    }
    respPayload, err = msg.GetResponseBytes()
    if err != nil {
        ...
    }
}


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號