温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

springboot+HttpInvoke如何实现RPC调用

发布时间:2022-03-07 09:39:50 来源:亿速云 阅读:273 作者:小新 栏目:开发技术

小编给大家分享一下springboot+HttpInvoke如何实现RPC调用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

开始用springboot2+hession4实现RPC服务时,发现第一个服务可以调用成功,但第二个就一直报'<'isanunknowncode。第一个服务还是可以调用的。参考网上的方法,客户端与服务端hession版本保持一致,查看本地版本是一致的, 换成其他版本也没有效果。设置重载方法为true,都没有效果。如果有其他小伙伴有过解决方法,望指正。 后改用用了spring自带的HTTPInvoke。现记录如下:

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、客户端,将接口交由代理去执行远程方法

@Configuration
public class ClientRpcConfig {
 @Bean
 public HttpInvokerProxyFactoryBean rpcService() {
  HttpInvokerProxyFactoryBean httpInvokerProxyFactoryBean = new HttpInvokerProxyFactoryBean();
  httpInvokerProxyFactoryBean.setServiceUrl(server_url);
  httpInvokerProxyFactoryBean.setServiceInterface(xxxService.class);
  return httpInvokerProxyFactoryBean;
 }
}

注意点

1)、服务端与客户端接口名一致、方法参数一致

2)、如果接口参数是对象的话,参数对象须实现序列化

3)、接口参数是对象的话,服务端与客户端对象名要一致、包路径也得一致。 不然会报找不到类

3、将接口注入在所需要的地方即可实现远程调用接口所定义的方法

看完了这篇文章,相信你对“springboot+HttpInvoke如何实现RPC调用”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI