springboot+HttpInvoke?實現(xiàn)RPC調(diào)用的方法
開始用springboot2+hession4實現(xiàn)RPC服務時,發(fā)現(xiàn)第一個服務可以調(diào)用成功,但第二個就一直報'<'isanunknowncode。第一個服務還是可以調(diào)用的。參考網(wǎng)上的方法,客戶端與服務端hession版本保持一致,查看本地版本是一致的, 換成其他版本也沒有效果。設(shè)置重載方法為true,都沒有效果。如果有其他小伙伴有過解決方法,望指正。 后改用用了spring自帶的HTTPInvoke?,F(xiàn)記錄如下:
1、將服務端的服務暴露出來
@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í)行遠程方法
@Configuration
public class ClientRpcConfig {
@Bean
public HttpInvokerProxyFactoryBean rpcService() {
HttpInvokerProxyFactoryBean httpInvokerProxyFactoryBean = new HttpInvokerProxyFactoryBean();
httpInvokerProxyFactoryBean.setServiceUrl(server_url);
httpInvokerProxyFactoryBean.setServiceInterface(xxxService.class);
return httpInvokerProxyFactoryBean;
}
}注意點
1)、服務端與客戶端接口名一致、方法參數(shù)一致
2)、如果接口參數(shù)是對象的話,參數(shù)對象須實現(xiàn)序列化
3)、接口參數(shù)是對象的話,服務端與客戶端對象名要一致、包路徑也得一致。 不然會報找不到類
3、將接口注入在所需要的地方即可實現(xiàn)遠程調(diào)用接口所定義的方法
到此這篇關(guān)于springboot+HttpInvoke 實現(xiàn)RPC調(diào)用的文章就介紹到這了,更多相關(guān)springboot RPC調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mybatis和orcale update語句中接收參數(shù)為對象的實例代碼
Mybatis的 mapper.xml 中 update 語句使用 if 標簽判斷對像屬性是否為空值。本文重點給大家介紹Mybatis和orcale update語句中接收參數(shù)為對象的實例代碼,需要的朋友參考下吧2017-09-09
如何解決Maven打包時每次都出現(xiàn)Download maven-metadata.xml卡住問題
這篇文章主要介紹了如何解決Maven打包時每次都出現(xiàn)Download maven-metadata.xml卡住問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05

