dubbo远程调用接口

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

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

 

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

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

其中com.aaa.interface是包名

ToInterService是类名

sendService是方法名

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

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

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

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

           需要注意:本地新建类的包名,类型,以及方法要和提供的一致,可以让客户提供,自行复制粘贴即可

        

package com.aaa.interface;

import webservice.provider.prpall.bean.VoucherRequestRequest;

public abstract interface ToInterService
{
    public abstract String sendService(String param);
}

  3.加载spring-dubbo.xml

  4.测试

    @Autowired
	ToInterService toInterService;

	public void test() {
		System.out.println("开始");
		String result=toInterService.sendService("aa");
		System.out.println("结果=="+result);
		
	}
<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.8.4</version>
			<exclusions>
				<exclusion>
					<artifactId>curator-framework</artifactId>
					<groupId>org.apache.curator</groupId>
				</exclusion>
				<exclusion>
					<artifactId>curator-client</artifactId>
					<groupId>org.apache.curator</groupId>
				</exclusion>
				<exclusion>
					<artifactId>guava</artifactId>
					<groupId>com.google.guava</groupId>
				</exclusion>
				<exclusion>
					<artifactId>spring-web</artifactId>
					<groupId>org.springframework</groupId>
				</exclusion>
			</exclusions>
		</dependency>
		<!-- zookeeper注册中心工具包 -->
		<dependency>
		    <groupId>org.apache.zookeeper</groupId>
		    <artifactId>zookeeper</artifactId>
		    <version>3.4.9</version>
		</dependency>
		<dependency>
			<groupId>com.101tec</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.9</version>
		</dependency>
		<!-- JunitTest依赖,仅仅junit测试使用 -->
		<dependency>
		    <groupId>org.eclipse.jetty.websocket</groupId>
		    <artifactId>websocket-server</artifactId>
		    <version>9.2.10.v20150310</version>
		    <scope>test</scope>
		</dependency>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值