SpringCloud系列之Nacos+Dubbo应用篇

目录

前言

本文在前篇文章《SpringCloud系列之Nacos应用篇》基础上集成Dubbo,公司项目中新项目采用SpringCloud(后续会逐渐替换至spring cloud alibaba全家桶),老项目采用传统SSM+Dubbo,部分业务上新老项目都有所涉及,原先少许业务上是直接通过http请求来处理新老项目交互的,总觉得这样做不够优雅,也不利于维护,于是自己调研调研看。
在前篇《SpringCloud系列之集成Dubbo应用篇》文章中Dubbo是依托zookeeper作为服务注册发现组件,这次项目中以SpirngCloud,Nacos,Dubbo三者集成起来,减少了Eureka、SpringConfig、zookeeper组件的投入,配置、服务注册发现都依赖Nacos服务,减少维护工作,死磕Nacos即可。

项目版本

spring-boot-version:2.2.5.RELEASE
spring-cloud.version:Hoxton.SR3
nacos.version:1.3.2
dubbo.version:2.6.9/2.7.6

项目说明

新项目模块间采用Feign进行相互交互,老项目模块间采用Dubbo进行交互,新老项目间采用Dubbo交互。在集成Dubbo时也针对Dubbo 2.6.x及Dubbo 2.7.x版本进行分别说明。

当然也可以都用Dubbo进行交互。

涉及Nacos配置信息,请查阅上篇文章《SpringCloud系列之Nacos应用篇》,本文只涉及新增Dubbo相关的配置,完整项目源码请查看本文文末项目源码。

项目结构

在这里插入图片描述

项目分支付模块和用户模块,支付模块提供Dubbo服务供用户模块消费,用户模块提供Feign服务供支付模块调用。

集成Dubbo2.6.x

集成Dubbo2.6.x系列版本中费了不少时间,主要涉及nacos-client版本中不同版本有些类所属包发生了变更,导致集成时提示找不到类,自己尝试调整了下依赖的版本,最终要么这个版本有这个问题,另外一个版本又有另一个问题,都不能很好解决,心想不会就这么凉凉了吧
常见问题如下
java.lang.NoClassDefFoundError: com/alibaba/nacos/client/naming/utils/StringUtils
java.lang.NoClassDefFoundError: com/alibaba/nacos/api/naming/NamingMaintainService
后来在Nacos Github上看到了这条issues,发现基本是同样的问题,就按照以下版本测试了下,居然成功了,后来又在此依赖版本上对相应版本进行了升级。
https://github.com/alibaba/nacos/issues/2022
在这里插入图片描述
最终依赖如下
pom.xml

        <!--nacos discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--nacos config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--dubbo-->
        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>0.2.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.6.9</version>
        </dependency>
        <!--dubbo nacos-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo-registry-nacos</artifactId>
            <version>2.6.7</version>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--nacos-->
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-all</artifactId>
            <version>4.1.31.Final</version>
        </dependency>
支付模块

application.properties

Dubbo 2.6.x 系列需在Dubbo配置项中增加dubbo.application.name配置项,不然再启动时会提示缺少该配置项

dubbo.application.name=pay-service
# dubbo扫描包路径
dubbo.scan.base-packages=com.chinawu.cloud.pay.service
# dubbo协议
dubbo.protocol.name=dubbo
# 随机端口
dubbo.protocol.port=-1
# zookeeper地址
dubbo.registry.address=nacos://127.0.0.1:8848

DPayService.java

@Service为Dubbo注解,import com.alibaba.dubbo.config.annotation.Service;

@Service
public class DPayService implements DPayFacade {

    @Override
    public String goToPay(String userName) {
        System.out.println("dubbo.method:goToPay request "+userName);
        return "dubbo.method:goToPay result:" + userName + " pay success";
    }
}

PayServiceApplication.java

SpringBoot 启动类需增加 @EnableDubbo 注解标签,不然服务没法暴露,注册

@SpringBootApplication
@EnableDiscoveryClient
@EnableAutoConfiguration
@EnableFeignClients(basePackages = {"com.chinawu.cloud.user.*"})
@EnableDubbo
public class PayServiceApplication {

    public static void main(String[] args) {
        SpringApplication.run(PayServiceApplication.class, args);
    }

}
用户模块

application.properties

dubbo.application.name=user-service
# dubbo扫描包路径
dubbo.scan.base-packages=com.chinawu.cloud.user.service
# dubbo协议
dubbo.protocol.name=dubbo
# 随机端口
dubbo.protocol.port=-1
# zookeeper地址
dubbo.registry.address=nacos://127.0.0.1:8848

UserController.java

@RestController
@RequestMapping("/user")
@RefreshScope
public class UserController {

    @Value("${spring.datasource.url}")
    private String datasourceUrl;

    // Dubbo服务消费
    @Reference(check = false)
    DPayFacade dPayFacade;


    /**
     * <p >
     * 功能:获取数据源连接配置信息
     * </p>
     * @param
     * @author wuyubin
     * @date  2020年9月3日
     * @return
     */
    @RequestMapping("/getDatasourceUrl")
    public String getDatasourceUrl() {
        return datasourceUrl;
    }

    /**
     * <p >
     * 功能:测试Dubbo服务调用
     * </p>
     * @param
     * @author wuyubin
     * @date  2020年9月3日
     * @return
     */
    @RequestMapping("/goToPay")
    public String goToPay() {
        return dPayFacade.goToPay("wuyubin");
    }
}

集成Dubbo2.7.x

集成Dubbo2.7.x系列版本,相比就简单不少,直接引入如下依赖
pom.xml

		<!--nacos discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--nacos config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--dubbo-->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.8</version>
        </dependency>
        <!--dubbo nacos-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo-registry-nacos</artifactId>
            <version>2.7.6</version>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--nacos-->
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>1.3.2</version>
        </dependency>
支付模块

application.properties

# dubbo扫描包路径
dubbo.scan.base-packages=com.chinawu.cloud.pay.service
# dubbo协议
dubbo.protocol.name=dubbo
# 随机端口
dubbo.protocol.port=-1
# zookeeper地址
dubbo.registry.address=nacos://127.0.0.1:8848

DPayService.java

@Service 为Dubbo注解,import org.apache.dubbo.config.annotation.Service;

@Service
public class DPayService implements DPayFacade {

    @Override
    public String goToPay(String userName) {
        System.out.println("dubbo.method:goToPay request "+userName);
        return "dubbo.method:goToPay result:" + userName + " pay success";
    }
}
用户模块

application.properties

# dubbo扫描包路径
dubbo.scan.base-packages=com.chinawu.cloud.user.service
# dubbo协议
dubbo.protocol.name=dubbo
# 随机端口
dubbo.protocol.port=-1
# zookeeper地址
dubbo.registry.address=nacos://127.0.0.1:8848

UserController.java

@RestController
@RequestMapping("/user")
@RefreshScope
public class UserController {

    @Value("${spring.datasource.url}")
    private String datasourceUrl;
    // Dubbo服务消费
    @Reference(check = false)
    DPayFacade dPayFacade;

    /**
     * <p >
     * 功能:获取数据源连接配置信息
     * </p>
     * @param
     * @author wuyubin
     * @date  2020年9月3日
     * @return
     */
    @RequestMapping("/getDatasourceUrl")
    public String getDatasourceUrl() {
        return datasourceUrl;
    }

    /**
     * <p >
     * 功能:测试Dubbo服务调用
     * </p>
     * @param
     * @author wuyubin
     * @date  2020年9月3日
     * @return
     */
    @RequestMapping("/goToPay")
    public String goToPay() {
        return dPayFacade.goToPay("wuyubin");
    }
}

测试验证

支付模块和用户模块都启动后,我们进入Nacos后台进行查看,发现服务都已注册上,如下图
在这里插入图片描述
请求下用户模块预留的接口(内部通过Dubbo请求支付模块),如下图
http://localhost:9012/user/goToPay
在这里插入图片描述
请求下支付模块预留的接口(内部通过Feign请求用户模块),如下图
http://localhost:9011/pay/get
在这里插入图片描述
至此Nacos和Dubbo已整合至SpringCloud。

参考资料

https://github.com/alibaba/spring-cloud-alibaba
https://nacos.io/zh-cn/docs/use-nacos-with-dubbo.html

系列文章

SpringCloud系列之配置中心(Config)使用说明

SpringCloud系列之服务注册发现(Eureka)应用篇

SpringCloud系列之网关(Gateway)应用篇

SpringCloud系列之集成Dubbo应用篇

SpringCloud系列之集成分布式事务Seata应用篇

SpringCloud系列之Nacos应用篇

项目源码

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤: 1. 创建 Spring Boot 项目 使用 Spring Initializr 创建一个 Spring Boot 项目,选择需要的依赖,包括 Spring Web、Spring Cloud Discovery、Dubbo Starter、Mybatis Plus Starter、RocketMQ Starter、Sentinel Starter、Seata Starter、MySQL Driver 等。 2. 配置 Nacos 注册中心和配置中心 在 application.properties 文件中添加以下配置: ``` spring.cloud.nacos.discovery.server-addr=localhost:8848 spring.cloud.nacos.config.server-addr=localhost:8848 spring.cloud.nacos.config.namespace= spring.cloud.nacos.config.group=DEFAULT_GROUP spring.cloud.nacos.config.prefix=${spring.application.name} spring.cloud.nacos.config.file-extension=properties ``` 其中,server-addr 为 Nacos 的地址,namespace 为命名空间,group 为配置组,prefix 为配置文件前缀,file-extension 为配置文件后缀。 3. 配置 Dubbo 服务提供者和消费者 在 application.properties 文件中添加以下配置: ``` # Dubbo Provider spring.dubbo.application.name=${spring.application.name} spring.dubbo.registry.address=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.scan=tech.chitosh.oceanus.service # Dubbo Consumer spring.dubbo.consumer.check=false spring.dubbo.consumer.registry=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.consumer.timeout=5000 ``` 其中,application.name 为应用名称,scan 为扫描的 Dubbo 服务接口包名,check 为是否启用 Dubbo 健康检查,timeout 为 Dubbo 超时时间。 4. 配置 Mybatis Plus 和 MySQL 在 application.properties 文件中添加以下配置: ``` # Mybatis Plus mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.configuration.map-underscore-to-camel-case=true mybatis-plus.configuration.cache-enabled=true # MySQL spring.datasource.url=jdbc:mysql://localhost:3306/oceanus?useUnicode=true&characterEncoding=utf8&useSSL=false&allowMultiQueries=true&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` 其中,mapper-locations 为 Mybatis Plus 的 Mapper.xml 文件路径,map-underscore-to-camel-case 为下划线转驼峰的配置,url 为 MySQL 的连接字符串,username 和 password 为数据库用户名和密码。 5. 配置 RocketMQ 在 application.properties 文件中添加以下配置: ``` # RocketMQ rocketmq.name-server=localhost:9876 rocketmq.producer.group=oceanus rocketmq.consumer.group=oceanus ``` 其中,name-server 为 RocketMQ 的地址,producer.group 为生产者组,consumer.group 为消费者组。 6. 配置 Sentinel 在 application.properties 文件中添加以下配置: ``` # Sentinel spring.cloud.sentinel.transport.dashboard=localhost:8080 spring.cloud.sentinel.transport.port=8719 spring.cloud.sentinel.datasource.ds.nacos.server-addr=localhost:8848 spring.cloud.sentinel.datasource.ds.nacos.data-id=${spring.cloud.nacos.config.prefix}-sentinel spring.cloud.sentinel.datasource.ds.nacos.group=SENTINEL_GROUP ``` 其中,transport.dashboard 为 Sentinel 控制台地址,transport.port 为 Sentinel 所用的端口,datasource.ds.nacos.server-addr 为 Nacos 的地址,data-id 为 Sentinel 数据源的名称,group 为 Sentinel 数据源所在的组。 7. 配置 Seata 在 application.properties 文件中添加以下配置: ``` # Seata spring.cloud.alibaba.seata.tx-service-group=my_test_tx_group spring.cloud.alibaba.seata.enable-auto-data-source-proxy=true spring.cloud.alibaba.seata.config.type=nacos spring.cloud.alibaba.seata.config.nacos.server-addr=localhost:8848 spring.cloud.alibaba.seata.config.nacos.namespace= spring.cloud.alibaba.seata.config.nacos.group=SEATA_GROUP ``` 其中,tx-service-group 为 Seata 分布式事务组名称,enable-auto-data-source-proxy 为是否启用 Seata 数据源代理,config.type 为 Seata 配置类型,config.nacos.server-addr 为 Nacos 的地址,config.nacos.namespace 为命名空间,config.nacos.group 为 Seata 配置所在的组。 8. 编写代码 按照业务需求编写 Dubbo 服务接口和实现、Mybatis Plus DAO 层、RocketMQ 生产者和消费者、Sentinel 熔断降级规则等代码。 以上就是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤,希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值