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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 2021-12-10 关于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;
相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
7天前
|
Dubbo Java 应用服务中间件
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用
微服务学习 | Springboot整合Dubbo+Nacos实现RPC调用
|
13天前
|
Java API 微服务
【Spring Boot系列】通过OpenAPI规范构建微服务服务接口
【4月更文挑战第5天】通过OpenAPI接口构建Spring Boot服务RestAPI接口
|
23天前
|
Java Linux
Springboot 解决linux服务器下获取不到项目Resources下资源
Springboot 解决linux服务器下获取不到项目Resources下资源
|
1月前
|
NoSQL Java Redis
SpringBoot集成Redis解决表单重复提交接口幂等(亲测可用)
SpringBoot集成Redis解决表单重复提交接口幂等(亲测可用)
355 0
|
1月前
|
Java API Spring
SpringBoot项目调用HTTP接口5种方式你了解多少?
SpringBoot项目调用HTTP接口5种方式你了解多少?
85 2
|
1月前
|
前端开发 JavaScript Java
6个SpringBoot 项目拿来就可以学习项目经验接私活
6个SpringBoot 项目拿来就可以学习项目经验接私活
35 0
|
1月前
|
存储 JSON Java
SpringBoot集成AOP实现每个接口请求参数和返回参数并记录每个接口请求时间
SpringBoot集成AOP实现每个接口请求参数和返回参数并记录每个接口请求时间
28 2
|
5天前
|
负载均衡 监控 Dubbo
秒懂Dubbo接口(原理篇)
【4月更文挑战第25天】秒懂Dubbo接口(原理篇)
19 3
秒懂Dubbo接口(原理篇)
|
2天前
|
存储 Java 应用服务中间件
Springboot项目打war包部署到外置tomcat容器【详解版】
该文介绍了将Spring Boot应用改为war包并在外部Tomcat中部署的步骤:1) 修改pom.xml打包方式为war;2) 排除内置Tomcat依赖;3) 创建`ServletInitializer`类继承`SpringBootServletInitializer`;4) build部分需指定`finalName`;5) 使用`mvn clean package`打包,将war包放入外部Tomcat的webapps目录,通过startup脚本启动Tomcat并访问应用。注意,应用访问路径和静态资源引用需包含war包名。
|
2天前
|
Java
SpringBoot 项目启动初始化一个Map对象到内存
SpringBoot 项目启动初始化一个Map对象到内存