Kitex[ka?t’eks] 字節(jié)跳動內(nèi)部的 Golang 微服務(wù) RPC 框架,具有高性能、強可擴展的特點,在字節(jié)內(nèi)部已廣泛使用。如果對微服務(wù)性能有要求,又希望定制擴展融入自己的治理體系,Kitex 會是一個不錯的選擇。
使用自研的高性能網(wǎng)絡(luò)庫 Netpoll,性能相較 go net 具有顯著優(yōu)勢。
提供了較多的擴展接口以及默認擴展實現(xiàn),使用者也可以根據(jù)需要自行定制擴展,具體見下面的框架擴展。
RPC 消息協(xié)議默認支持 ?Thrift
?、?Kitex Protobuf
?、?gRPC
?。Thrift 支持 Buffered 和 Framed 二進制協(xié)議;Kitex Protobuf 是 Kitex 自定義的 Protobuf 消息協(xié)議,協(xié)議格式類似 Thrift;gRPC 是對 gRPC 消息協(xié)議的支持,可以與 gRPC 互通。除此之外,使用者也可以擴展自己的消息協(xié)議。
傳輸協(xié)議封裝消息協(xié)議進行 RPC 互通,傳輸協(xié)議可以額外透傳元信息,用于服務(wù)治理,Kitex 支持的傳輸協(xié)議有 ?TTHeader
?、?HTTP2
?。TTHeader 可以和 Thrift、Kitex Protobuf 結(jié)合使用;HTTP2 目前主要是結(jié)合 gRPC 協(xié)議使用,后續(xù)也會支持 Thrift。
支持 ?PingPong
?、?Oneway
?、雙向 ?Streaming
?。其中 Oneway 目前只對 Thrift 協(xié)議支持,雙向 Streaming 只對 gRPC 支持,后續(xù)會考慮支持 Thrift 的雙向 Streaming。
支持服務(wù)注冊/發(fā)現(xiàn)、負載均衡、熔斷、限流、重試、監(jiān)控、鏈路跟蹤、日志、診斷等服務(wù)治理模塊,大部分均已提供默認擴展,使用者可選擇集成。
Kitex 內(nèi)置代碼生成工具,可支持生成 ?Thrift
?、?Protobuf
?以及腳手架代碼。
性能測試只能提供相對參考,工業(yè)場景下,有諸多因素可以影響實際的性能表現(xiàn)。
由于開源社區(qū)缺少支持 thrift 的優(yōu)秀 RPC 框架,當(dāng)前對比項目為 grpc, rpcx, 均使用 protobuf 協(xié)議。
我們通過 測試代碼 比較了它們的性能,測試表明 Kitex 具有明顯優(yōu)勢。
CPU: Intel(R) Xeon(R) Gold 5118 CPU @ 2.30GHz, 4 cores
Memory: 8GB
OS: Debian 5.4.56.bsk.1-amd64 x86_64 GNU/Linux
Go: 1.15.4
Netpoll: 自研的高性能網(wǎng)絡(luò)庫,Kitex 默認集成的。
kitex-contrib:Kitex 的部分?jǐn)U展庫,使用者可以根據(jù)需求通過 Option 集成進 Kitex 中。
Example:Kitex 的使用示例。
字節(jié)跳動 Go RPC 框架 Kitex 性能優(yōu)化實踐
字節(jié)跳動在 Go 網(wǎng)絡(luò)庫上的實踐
更多建議: