1.前言
这是一个基于SpringBoot整合Apache Dubbo+Nacos的极简教程,笔者使用到的技术及版本如下:
SpringBoot 2.4.5
Dubbo 2.7.11
Nacos 2.0.1(自行安装)
Dubbo官网:https://dubbo.apache.org/zh/
Nacos官网:https://nacos.io/zh-cn/docs/quick-start.html
2.目录结构
dubbo-client:生产者消费者共有接口
dubbo-consumer:消费者
dubbo-provider:生产者
[图片上传失败...(image-157d1c-1626688485934)]
3.配置文件
pom核心依赖
org.apache.dubbo
dubbo-spring-boot-starter
2.7.11
com.alibaba.boot
nacos-discovery-spring-boot-starter
0.2.7
com.alibaba.spring
spring-context-support
pom配置文件全文
4.0.0
pom
dubbo-provider
dubbo-client
dubbo-consumer
org.springframework.boot
spring-boot-starter-parent
2.4.5
xyz.hcworld
rpcscaffold
0.0.1-SNAPSHOT
rpcscaffold
SpringBoot整合Apache Dubbo+Nacos的极简教程
1.8
org.apache.dubbo
dubbo-spring-boot-starter
2.7.11
com.alibaba.boot
nacos-discovery-spring-boot-starter
0.2.7
com.alibaba.spring
spring-context-support
org.projectlombok
lombok
true
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-maven-plugin
org.projectlombok
lombok
注释:需要去除spring-context-support依赖,否则运行不起来,但是去除后消费者会报错却不影响使用。
4.接口模块
定义一个消费者和生产者共同拥有的接口子模块。
package xyz.hcworld.service;
/**
* 注入接口
* @ClassName: DemoService
* @Author: 张红尘
* @Date: 2021-05-24
* @Version:1.0
*/
public interface DemoService {
/**
* 测试方法获取service参数
* @param name
* @return
*/
String sayName(String name);
}
5.生产者模块
pom核心依赖
依赖加入接口模块。
xyz.hcworld
dubbo-client
0.0.1-SNAPSHOT
yml配置文件
# 设置nacos的地址(配置中心)
nacos:
discovery:
server-addr: 192.168.2.142:8848
# 设置dubbo的参数
dubbo:
application:
# 当前消费者的配置名
name: dubbo-provider-demo
registry:
address: nacos://192.168.2.142:8848
# 协议(缺省值)
protocol:
name: dubbo
port: -1
# 当前接口的名字与版本
demo:
service:
version: 1.0.0
name: demoService
类
新版Dubbo将 @Service标注为过时,所以最新的注解应当使用 @DubboService ,如果使用 @Service容易与Spring的 @Service搞混。
package xyz.hcworld.service.impl;
import org.apache.dubbo.config.annotation.DubboService;
import org.apache.dubbo.rpc.RpcContext;
import org.springframework.beans.factory.annotation.Value;
import xyz.hcworld.service.DemoService;
/**
* @ClassName: DemoServiceImpl
* @Author: 张红尘
* @Date: 2021-05-24
* @Version:1.0
*/
@DubboService(interfaceClass = DemoService.class,interfaceName = "${demo.service.name}",version = "${demo.service.version}")
public class DemoServiceImpl implements DemoService {
@Value("${demo.service.name}")
private String serviceName;
@Override
public String sayName(String name) {
RpcContext rpcContext = RpcContext.getContext();
return String.format("Service [name :%s , port : %d] %s(\"%s\") : Hello,%s",
serviceName,
rpcContext.getLocalPort(),
rpcContext.getMethodName(),
name,
name);
}
}
6.消费者模块
pom文件与同生产者模块一致,yml文件修改name其余也与生产者模块一致。
dubbo:
application:
# 当前消费者的配置名
name: dubbo-consumer-demo
类
生产者消费者的接口名与接口版本必须一致。使用@DubboReference注入远程接口。
package xyz.hcworld.controller;
import org.apache.dubbo.config.annotation.DubboReference;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import xyz.hcworld.service.DemoService;
/**
* @ClassName: DubboController
* @Author: 张红尘
* @Date: 2021-05-24
* @Version:1.0
*/
@RestController
public class DubboController {
@DubboReference(interfaceClass = DemoService.class,interfaceName = "${demo.service.name}",version = "${demo.service.version}")
private DemoService demoService;
@RequestMapping("/hello")
public String sayHello(){
return demoService.sayName("张");
}
}
7.结果
生产者启动结果
[图片上传失败...(image-85d663-1626688485934)]
消费者启动结果
[图片上传失败...(image-6ddc99-1626688485934)]
注释:报错是因为去除了com.alibaba.spring下的spring-context-support,但并不影响使用,不去除将无法启动,如果有其他异常可以与作者进行讨论研究。
浏览器请求结果
[图片上传失败...(image-84c6b0-1626688485934)]
Nacos可视化
[图片上传失败...(image-c30ff9-1626688485934)]
[图片上传失败...(image-b18dba-1626688485934)]
[图片上传失败...(image-b5328f-1626688485934)]
8.项目下载地址
GitHub:https://github.com/z875479694h/RpcScaffold
联系方式
公众号:青山有录
Github:https://github.com/z875479694h
博客:https://www.hcworld.xyz