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

微服务搭建(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.xdnf.cn/news/19181.html

相关文章:

  • vue+Django 双推荐算法旅游大数据可视化系统Echarts mysql数据库 带爬虫
  • 【学Python自动化】 4. Python 控制流与函数学习笔记
  • 嵌入式Linux驱动开发:ICM20608六轴传感器SPI驱动
  • 深度学习核心损失函数详解:交叉熵、MSE、对比学习(InfoNCE)
  • 科技感网页计时器.html
  • Linux系统统计用户登录和注销时间的工具之ac
  • 【计算机408计算机网络】第四章:自底向上五层模型之网络层
  • 使用python格式化nginx配置文件
  • OSI与TCP/IP各层功能详解
  • 吴恩达机器学习作业八:SVM支持向量机
  • 从零开始的python学习——注释与运算符
  • 机器学习 - Kaggle项目实践(6)Dogs vs. Cats Redux: Kernels Edition 猫狗二分类
  • 【Android】OkHttp发起GET请求 POST请求
  • 「从 0 到 1」的 Python-requests 爬虫完整教程
  • 内网后渗透攻击--跨域攻击
  • for in+逻辑表达式 生成迭代对象,最后转化为列表 ——注意list是生成器转化为列表,但[生成器]得到的就是一个列表,其中包含一个生成器元素
  • 字节跳动出品的 AI开发工具 : Trae:开启 AI 编程新时代
  • 解读IEC 62477-2-2018
  • 05.《ARP协议基础知识探秘》
  • 基于大模型与 PubMed 检索的光谱数据分析系统
  • 嵌入式学习笔记--LINUX系统编程--DAY03进程控制
  • Linux 笔记 Day01|课程结构
  • ubuntu24.04 qt6安装
  • Azure DevOps cherry pick
  • PromptPerfect-将你的提示词提升到完美
  • Java全栈开发面试实战:从基础到高并发的全面解析
  • 可转换公司债Level-2高频交易五档Tick级分钟历史数据分析指南
  • 2025年09月计算机二级Python选择题每日一练——第十二期
  • 目标和-背包dp
  • watch 与 computed:Vue3响应式的抉择