您好,登錄后才能下訂單哦!
小編給大家分享一下springboot+HttpInvoke如何實(shí)現(xiàn)RPC調(diào)用,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
開始用springboot2+hession4實(shí)現(xiàn)RPC服務(wù)時(shí),發(fā)現(xiàn)第一個(gè)服務(wù)可以調(diào)用成功,但第二個(gè)就一直報(bào)'<'isanunknowncode。第一個(gè)服務(wù)還是可以調(diào)用的。參考網(wǎng)上的方法,客戶端與服務(wù)端hession版本保持一致,查看本地版本是一致的, 換成其他版本也沒有效果。設(shè)置重載方法為true,都沒有效果。如果有其他小伙伴有過解決方法,望指正。 后改用用了spring自帶的HTTPInvoke?,F(xiàn)記錄如下:
1、將服務(wù)端的服務(wù)暴露出來
@Configuration public class HttpInvokeServiceConfig { @Bean("/xxx") public HttpInvokerServiceExporter rpcService(xxxService xxxService) { HttpInvokerServiceExporter httpInvokerServiceExporter = new HttpInvokerServiceExporter(); httpInvokerServiceExporter.setService(xxxService); httpInvokerServiceExporter.setServiceInterface(xxxService.class); return httpInvokerServiceExporter; } }
2、客戶端,將接口交由代理去執(zhí)行遠(yuǎn)程方法
@Configuration public class ClientRpcConfig { @Bean public HttpInvokerProxyFactoryBean rpcService() { HttpInvokerProxyFactoryBean httpInvokerProxyFactoryBean = new HttpInvokerProxyFactoryBean(); httpInvokerProxyFactoryBean.setServiceUrl(server_url); httpInvokerProxyFactoryBean.setServiceInterface(xxxService.class); return httpInvokerProxyFactoryBean; } }
注意點(diǎn)
1)、服務(wù)端與客戶端接口名一致、方法參數(shù)一致
2)、如果接口參數(shù)是對象的話,參數(shù)對象須實(shí)現(xiàn)序列化
3)、接口參數(shù)是對象的話,服務(wù)端與客戶端對象名要一致、包路徑也得一致。 不然會報(bào)找不到類
3、將接口注入在所需要的地方即可實(shí)現(xiàn)遠(yuǎn)程調(diào)用接口所定義的方法
看完了這篇文章,相信你對“springboot+HttpInvoke如何實(shí)現(xiàn)RPC調(diào)用”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。