当前位置: 首页 > news >正文

微服务搭建(SpringBoot + Dubbo + Nacos)

1.项目接口

2. 编辑pom.xml和application.yml文件

2.1父工程

pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.10</version><relativePath/></parent><groupId>com.hanxun</groupId><artifactId>crmbe-service-backend</artifactId><packaging>pom</packaging><version>1.0</version><properties><java.version>1.8</java.version><spring.boot.version>2.7.10</spring.boot.version><dubbo.version>3.0.10</dubbo.version><nacos-client.version>2.1.1</nacos-client.version></properties><modules><module>crmbe-api</module><module>crmbe-consumer</module><module>crmbe-provider</module></modules><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><version>${spring.boot.version}</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>${spring.boot.version}</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><version>${spring.boot.version}</version><scope>test</scope></dependency><!-- Dubbo核心依赖 --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>${dubbo.version}</version></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><version>${dubbo.version}</version><exclusions><!-- 排除适配层自带的 Nacos 客户端,避免版本冲突 --><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>${nacos-client.version}</version></dependency><dependency><groupId>com.alibaba.spring</groupId><artifactId>spring-context-support</artifactId><version>1.0.11</version></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.1-jre</version></dependency></dependencies></dependencyManagement>
</project>

2.2 api 模块

pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.hanxun</groupId><artifactId>crmbe-service-backend</artifactId><version>1.0</version></parent><groupId>com.hanxun</groupId><artifactId>crmbe-api</artifactId><version>1.0</version><dependencies><dependency><groupId>com.alibaba.spring</groupId><artifactId>spring-context-support</artifactId></dependency></dependencies></project>

2.3 consumer 模块

代码结构:

dubbo注解:

Controller中使用 @DubboReference  进行依赖注入

@RestController
@RequestMapping("/test")
public class UserController {@DubboReference(version = "1.0")private UserService userService;@GetMapping("/get")public Object get(String id){List<SysUser> userList= userService.getUserList();//        return "hello world !!!";return userList;}
}
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.hanxun</groupId><artifactId>crmbe-service-backend</artifactId><version>1.0</version></parent><groupId>com.hanxun</groupId><artifactId>crmbe-consumer</artifactId><version>1.0</version><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.hanxun</groupId><artifactId>crmbe-api</artifactId><version>1.0</version></dependency><!-- dubbo --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId></dependency><dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-client</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId></dependency></dependencies><build><finalName>${project.artifactId}</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>${spring.boot.version}</version><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build></project>
 yml文件
# 应用名称
spring:application:name: crmbe-consumer
#  cloud:# Nacos配置中心
#    nacos:
#      server-addr: 127.0.0.1:8848 # Nacos 服务器地址
#      username: nacos # Nacos 账号
#      password: nacos # Nacos 密码
#      discovery: # 【配置中心】配置项
#        namespace: dev # 命名空间。这里使用 dev 开发环境
#        group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
#        metadata:
#          version: 1.0.0 # 服务实例的版本号,可用于灰度发布
#      config: # 【注册中心】配置项
#        namespace: dev # 命名空间。这里使用 dev 开发环境
#        group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUPconfig:import:- optional:nacos:application.yml- optional:nacos:${spring.application.name}.yml# Dubbo配置
dubbo:application:name: crmbe-consumerlogger: slf4jprotocol:name: dubboport: -1registry:address: nacos://127.0.0.1:8848parameters:namespace: dev# 服务端口
server:port: 8082servlet:context-path: /crmbe-consumer

2.4 provider模块

代码结构:

dubbo 注解:

UserSeviceImpl 使用 @DubboService 注解 暴露服务

@DubboService(version = "1.0")
public class UserSeviceImpl implements UserService {@Overridepublic List<SysUser> getUserList() {List<SysUser> userlist = new ArrayList<SysUser>();SysUser user1 = new SysUser("张三",20, LocalDateTime.now());SysUser user2 = new SysUser("李四",30,LocalDateTime.now());SysUser user3 = new SysUser("王五",31,LocalDateTime.now());userlist.add(user1);userlist.add(user2);userlist.add(user3);userlist.add(user3);return userlist;}
}

Application 类加 @EnableDubbo

@EnableDubbo
@SpringBootApplication
public class CrmbeProviderApplication {public static void main(String[] args) {SpringApplication.run(CrmbeProviderApplication.class, args);System.out.println("--------------Dubbo Provider 启动成功-----------------");}}
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.hanxun</groupId><artifactId>crmbe-service-backend</artifactId><version>1.0</version></parent><artifactId>crmbe-provider</artifactId><version>1.0</version><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.hanxun</groupId><artifactId>crmbe-api</artifactId><version>1.0</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- dubbo --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId></dependency><dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-client</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId></dependency></dependencies><build><finalName>${project.artifactId}</finalName><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.8.1</version><configuration><!-- 明确指定 Java 版本为 1.8 --><source>1.8</source><target>1.8</target><!-- 可选:指定编码 --><encoding>UTF-8</encoding></configuration></plugin><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>${spring.boot.version}</version><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build></project>
 yml文件
# 应用名称
spring:application:name: crmbe-providerconfig:import:- optional:nacos:application.yml- optional:nacos:${spring.application.name}.yml# Dubbo配置
dubbo:application:name: crmbe-providerlogger: slf4jprotocol:name: dubboport: -1registry:address: nacos://127.0.0.1:8848parameters:namespace: devconfig-center:address: nacos://127.0.0.1:8848parameters:namespace: devscan:base-packages: com.hanxun# 服务端口
server:port: 8081

http://www.dtcms.com/a/358531.html

相关文章:

  • 【龙泽科技】汽车电气故障诊断仿真教学软件【迈腾380TSI】
  • 3.kafka常用命令
  • 元素滚动scrollIntoView
  • 2025年09月计算机二级Python选择题每日一练——第十二期
  • GD32入门到实战22--红外NEC通信协议
  • node.js ---文件读写(FS模块)
  • shell脚本第五阶段---shell函数与正则表达式
  • 机器学习时间序列算法进行随机划分数据是不合适的!
  • 一键掌控三线资源:极简 Shell 脚本实现 CPU·磁盘·内存可视化巡检
  • 鸿蒙ArkTS 核心篇-14-条件表达式(三目运算符)
  • ans1语法的一个例子nt5inf.cat
  • openEuler2403安装部署PostgreSQL17
  • 开发中使用——鸿蒙CoreSpeechKit让文字发声
  • 118、【OS】【Nuttx】【周边】效果呈现方案解析:作用域?
  • python pyqt5开发DoIP上位机【源码】
  • Spring代理的特点
  • Photoshop - Ps Camera Raw 滤镜
  • 【Python+requests】解决Python requests中的ProxyError:SSL版本错误问题详解
  • C++中的临时对象与移动语义——深入理解与实践
  • 消费 $83,用Claude 实现临床护理系统记录单(所见即所得版)
  • 拦截器Intercepter
  • 基于单片机智能垃圾桶/垃圾分类/语音垃圾桶
  • Spring MVC 参数绑定的默认行为解析
  • MySQL错误1449: The user specified as a definer (‘root‘@‘%‘) does not exist
  • MIT 6.5840 (Spring, 2024) 通关指南——Lab 1: MapReduce
  • JC系列串口通信说明
  • day45-Ansible流程控制
  • 同步/异步日志库
  • 佳易王钟表维修养护管理系统:开启钟表维修高效管理新篇章​就#软件操作教程
  • Compare With Java And Python