W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
對于 Dubbo-go 微服務(wù)框架,網(wǎng)絡(luò)協(xié)議為遠程過程調(diào)用中負責網(wǎng)絡(luò)通信的模塊,負責應(yīng)用層到網(wǎng)絡(luò)層的數(shù)據(jù)序列化、打包、請求發(fā)起、網(wǎng)絡(luò)端口監(jiān)聽等功能。Dubbo-go 為協(xié)議抽象了一套接口如下:
type Protocol interface { // Export service for remote invocation Export(invoker Invoker) Exporter // Refer a remote service Refer(url *common.URL) Invoker // Destroy will destroy all invoker and exporter, so it only is called once. Destroy() }
該接口包含三個方法。其中 Export 方法負責服務(wù)的暴露過程。入?yún)?invoker 為dubbo 的概念,其封裝了一個可以被調(diào)用的實例。在具體網(wǎng)絡(luò)協(xié)議(例如Triple)實現(xiàn)的 Export 方法中,會針對特定的協(xié)議,將封裝有一定邏輯的可調(diào)用實例 Invoker 以網(wǎng)絡(luò)端口監(jiān)聽的形式暴露給外部服務(wù),來自外部針對該網(wǎng)絡(luò)端口的請求將會被 Export 方法開啟的監(jiān)聽協(xié)程獲取,進而根據(jù)網(wǎng)絡(luò)協(xié)議進行拆解包和反序列化,得到解析后的請求數(shù)據(jù)。
Refer 方法負責服務(wù)的引用過程,其入?yún)?url 為 dubbo 框架通用的結(jié)構(gòu),可以描述一個希望引用的服務(wù),url 參數(shù)中包含了多個希望引用服務(wù)的參數(shù),例如對應(yīng)服務(wù)的接口名(interface),版本號(version),使用協(xié)議(protocol) 等等。在具體網(wǎng)絡(luò)協(xié)議(例如Triple)實現(xiàn)的 Refer 方法中,會將特定的網(wǎng)絡(luò)協(xié)議封裝到 Invoker 可調(diào)用實例的方法中,用戶層發(fā)起的 RPC 調(diào)用即可直接通過返回的 Invoker 對象,發(fā)起特定協(xié)議的網(wǎng)絡(luò)請求。
Destroy 方法作用為銷毀當前暴露的服務(wù),用于服務(wù)下線場景。Dubbo-go 框架有優(yōu)雅下線機制,可以在服務(wù)進程終止前以監(jiān)聽信號的形式,下線所有已啟動的服務(wù)。
Dubbo-go 3.0 版本支持的網(wǎng)絡(luò)協(xié)議和序列化方式如下:
協(xié)議 | 協(xié)議名 (用于配置) | 序列化方式 | 默認序列化方式 |
---|---|---|---|
Triple | tri | pb hessian2 msgpack custome | pb |
Dubbo | dubbbo | hessian2 | hessian2 |
gRPC | grpc | pb | pb |
jsonRPC | jsonrpc | json | json |
在快速開始章節(jié)可以看到,在配置的過程中將 Protocol 設(shè)置為 tri,表明使用 Triple 協(xié)議進行服務(wù)暴露和服務(wù)調(diào)用??焖匍_始章節(jié)使用的配置 API 進行配置的寫入,這樣的好處是無需使用配置文件。我們摘取出和網(wǎng)絡(luò)協(xié)議相關(guān)的內(nèi)容進行說明。
rc := config.NewRootConfigBuilder(). SetConsumer(config.NewConsumerConfigBuilder(). AddReference("GreeterClientImpl", config.NewReferenceConfigBuilder(). SetInterface("org.apache.dubbo.UserProvider"). SetProtocol("tri"). // set reference protcol to triple Build()). Build()). Build()
rc := config.NewRootConfigBuilder(). SetProvider(config.NewProviderConfigBuilder(). AddService("GreeterProvider", config.NewServiceConfigBuilder(). SetInterface("org.apache.dubbo.UserProvider"). SetProtocolIDs("tripleProtocolKey"). // use protocolID 'tripleProtocolKey' Build()). Build()). AddProtocol("tripleProtocolKey", config.NewProtocolConfigBuilder(). // define protocol config with protocolID 'tripleProtocolKey' SetName("tri"). // set service protocol to triple Build()). Build()
參考 samples/helloworld
dubbo: consumer: references: GreeterClientImpl: protocol: tri # set protcol to tri interface: com.apache.dubbo.sample.basic.IGreeter
dubbo: protocols: triple: # define protcol-id 'triple' name: tri # set protcol to tri port: 20000 # set port to be listened provider: services: GreeterProvider: protocol-ids: triple # use protocol-ids named 'triple' interface: com.apache.dubbo.sample.basic.IGreeter
下一
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: