2021-12-10 关于SpringBoot项目调用dubbo接口的笔记

SpringBoot项目调用dubbo接口的笔记

以下纯个人经历,不成体系,如有需求需要百度;具体步骤

一、pom.xml文件导入依赖

<!-此处是引入需要导入的jar包,需要调用的dubbo接口是放在这个jarbao下面的-->
	<dependency>
			<groupId>com.xxx.xxx</groupId>
			<artifactId>xxx-req-management-api</artifactId>
			<version>1.0.0-SNAPSHOT</version>
		</dependency>
			<!--	alibaba的dubbo包,也可以用apacha的	-->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.6.5</version>
		</dependency>
	<!--	ZooKeeper主要服务于分布式系统,做统一配置管理、统一命名服务、分布式锁、集群管理等杂活儿,简单说就是个分布式框架的”管家“-->
		<dependency>
			<groupId>org.apache.zookeeper</groupId>
			<artifactId>zookeeper</artifactId>
			<version>3.5.6</version>
		</dependency>
		<!--	个人理解:也是一个用到操作Zookeeper的jar包	-->
		<dependency>
			<groupId>com.101tec</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.10</version>
		</dependency>
	<!--	提供了一个抽象级别更高的API,来操作Zookeeper	-->
		<dependency>
			<groupId>org.apache.curator</groupId>
			<artifactId>curator-framework</artifactId>
			<version>5.1.0</version>
		</dependency>

二、编写配置信息

在SSM的配置文件里面写好注册中心的地址,以及端口号,可以通过注入的方式动态管理dev、prd访问地址;
在项目名.config目录下的配置文件写入信息,(我的是applicatin-dev.properties文件)如:

#dubbo的zookeeper配置
xxx.dubbo.registry.port=8090
xxx.dubbo.registry.address=zookeeper://168.63.65.196:2182?backup=168.63.65.197:2182,168.63.65.198:2182
注:多ip需要用逗号隔开

三、编写位置的xml文件

注:我的xmu文件名是dubbo-config.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">

    <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 -->
    <dubbo:application name="agiletp-consumer"/>
<!--配置注册中心的地址,可以百度以下参数的意思,参数是通过第二步的配置文件注入进来的-->
    <dubbo:registry id="agiletp-registry" address="${xxx.dubbo.registry.address}" port="${xxx.dubbo.registry.port}" timeout="30000" check="false"/>
    <!--这一步是将需要访问的jar包中的暴露的Service接入到当前项目-->
    <dubbo:reference id="dxxxProjectExternalService" interface="com.xxx.dpmp.external.api.DpmpProjectExternalService"
                     registry="agiletp-registry"
                     timeout="60000"
                     check="false"
                     reconnect="false"
                     version="1.0.0"
                     retries="0"/>
</beans>

四、将dubbo配置在SpringBoot启动类上注入

config目录下:根据路径访问dubbo-config.xml文件
@ImportResource({"file:config/dubbo-config.xml"})
resource路径下:根据路径访问dubbo-config.xml文件
@ImportResource("classpath:dubbo-config.xml")
classpath是指springboot项目的resourse路径

五、注入Service,调用方法即可

到这一步已经完成了dubbo接口配置的基本步骤,剩下的jar调用就和普通的service方法一致了,卓阳注解注入service

   @Autowired
    private DxxxProjectExternalService dxxxProjectExternalService;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值