dubbo远程调用接口

柔情只为你懂 2021-10-13 01:55 530阅读 0赞

最近做了一个项目需要使用dubbo调用远程接口,写出来分享一下

首先需要提供接口的人给你接口地址,注册中心地址,以及参数类型,参数类型可以是实体类,可以让客户直接把实体类发给你

接口地址就是类名地址以及要调用的方法

比如:com.aaa.interface.ToInterService.sendService

其中com.aaa.interface是包名

ToInterService是类名

sendService是方法名

准备工作做好了就开始干吧

  1. 配置dubbo的配置文件 spring-dubbo.xml

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    5. xsi:schemaLocation="http://www.springframework.org/schema/beans
    6. http://www.springframework.org/schema/beans/spring-beans.xsd
    7. http://code.alibabatech.com/schema/dubbo
    8. http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    9. <!-- 描述 -->
    10. <description>dubbo客户端服务配置</description>
    11. <!-- 消费者系统标志 -->
    12. <dubbo:application name="ACTUARY-SYSTEM"/>
    13. <!-- 注册中心地址 -->
    14. <dubbo:registry protocol="zookeeper" address="注册中心IP:端口号" client="zkclient"/>
    15. <!-- 消费者 -->
    16. <dubbo:reference id="toInterService"
    17. interface="com.aaa.interface.ToInterService"
    18. url="dubbo://调用服务IP:端口号" check="false" timeout="600000"/>
    19. </beans>

    需要注意的是:注册中心的address,以及消费者需要调用的interface,url要正确

  2. 在本地新建类com.aaa.interface.ToInterService

    1. 需要注意:本地新建类的包名,类型,以及方法要和提供的一致,可以让客户提供,自行复制粘贴即可
  1. package com.aaa.interface;
  2. import webservice.provider.prpall.bean.VoucherRequestRequest;
  3. public abstract interface ToInterService
  4. {
  5. public abstract String sendService(String param);
  6. }

3.加载spring-dubbo.xml

4.测试

  1. @Autowired
  2. ToInterService toInterService;
  3. public void test() {
  4. System.out.println("开始");
  5. String result=toInterService.sendService("aa");
  6. System.out.println("结果=="+result);
  7. }
  8. <dependency>
  9. <groupId>com.alibaba</groupId>
  10. <artifactId>dubbo</artifactId>
  11. <version>2.8.4</version>
  12. <exclusions>
  13. <exclusion>
  14. <artifactId>curator-framework</artifactId>
  15. <groupId>org.apache.curator</groupId>
  16. </exclusion>
  17. <exclusion>
  18. <artifactId>curator-client</artifactId>
  19. <groupId>org.apache.curator</groupId>
  20. </exclusion>
  21. <exclusion>
  22. <artifactId>guava</artifactId>
  23. <groupId>com.google.guava</groupId>
  24. </exclusion>
  25. <exclusion>
  26. <artifactId>spring-web</artifactId>
  27. <groupId>org.springframework</groupId>
  28. </exclusion>
  29. </exclusions>
  30. </dependency>
  31. <!-- zookeeper注册中心工具包 -->
  32. <dependency>
  33. <groupId>org.apache.zookeeper</groupId>
  34. <artifactId>zookeeper</artifactId>
  35. <version>3.4.9</version>
  36. </dependency>
  37. <dependency>
  38. <groupId>com.101tec</groupId>
  39. <artifactId>zkclient</artifactId>
  40. <version>0.9</version>
  41. </dependency>
  42. <!-- JunitTest依赖,仅仅junit测试使用 -->
  43. <dependency>
  44. <groupId>org.eclipse.jetty.websocket</groupId>
  45. <artifactId>websocket-server</artifactId>
  46. <version>9.2.10.v20150310</version>
  47. <scope>test</scope>
  48. </dependency>

发表评论

表情:
评论列表 (有 0 条评论,530人围观)

还没有评论,来说两句吧...

相关阅读

    相关 dubbo远程调用接口

    最近做了一个项目需要使用dubbo调用远程接口,写出来分享一下 首先需要提供接口的人给你接口地址,注册中心地址,以及参数类型,参数类型可以是实体类,可以让客户直接把实体类发给