springboot+HttpInvoke 实现RPC调用的方法

 更新时间:2022年03月07日 08:27:01   作者:秋水秋色  
RPC框架大家或多或少都用过,出自于阿里系的就有dubbo,HSF,sofaRPC等,今天通过本文给大家介绍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调用的文章就介绍到这了,更多相关springboot RPC调用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mybatis日志模块的适配器模式详解

    Mybatis日志模块的适配器模式详解

    这篇文章主要介绍了Mybatis日志模块的适配器模式详解,,mybatis用了适配器模式来兼容这些框架,适配器模式就是通过组合的方式,将需要适配的类转为使用者能够使用的接口
    2022-08-08
  • SpringData @Query和@Modifying注解原理解析

    SpringData @Query和@Modifying注解原理解析

    这篇文章主要介绍了SpringData @Query和@Modifying注解原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • 给JavaBean赋默认值并且转Json字符串的实例

    给JavaBean赋默认值并且转Json字符串的实例

    这篇文章主要介绍了给JavaBean赋默认值并且转Json字符串的实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Spring 中如何根据环境切换配置 @Profile

    Spring 中如何根据环境切换配置 @Profile

    这篇文章主要介绍了Spring中如何根据环境切换配置@Profile的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 基于jstl 标签的使用介绍

    基于jstl 标签的使用介绍

    本篇文章小编为大家介绍,基于jstl 标签的使用介绍,需要的朋友参考下
    2013-04-04
  • Java中对象初始化顺序的详细介绍

    Java中对象初始化顺序的详细介绍

    在Java中,类装载器把一个类装入Java虚拟机中,要经过三个步骤来完成:装载、链接和初始化,网上关于Java中对象初始化顺序的文章很多,这篇文章我们将详细介绍Java中对象初始化顺序。有需要的可以参考学习。
    2016-10-10
  • java断点续传功能实例(java获取远程文件)

    java断点续传功能实例(java获取远程文件)

    本文介绍了一种利用 Java 来实现断点续传的方法。
    2013-12-12
  • 打造一款代码命名工具的详细教程

    打造一款代码命名工具的详细教程

    这篇文章主要介绍了来,我们一起打造一款代码命名工具,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • Java Redis分布式锁的正确实现方式详解

    Java Redis分布式锁的正确实现方式详解

    这篇文章主要介绍了Java Redis分布式锁的正确实现方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • javascript与jsp发送请求到servlet的几种方式实例

    javascript与jsp发送请求到servlet的几种方式实例

    本文分别给出了javascript发送请求到servlet的5种方式实例与 jsp发送请求到servlet的6种方式实例
    2018-03-03

最新评论