[特殊字符] 基于Docker部署Nacos注册中心及微服务注册发现详解(含MySQL持久化配置)

📚 目录

  1. 项目背景与准备

  2. Docker部署Nacos并配置MySQL持久化

  3. 微服务注册到Nacos(item-service示例)

  4. 微服务服务发现与调用(cart-service示例)

  5. 小结


1. 项目背景与准备

在微服务架构中,服务注册与发现是基础能力,能帮助我们动态管理服务节点,实现高可用、动态扩展。

Nacos 是阿里巴巴开源的一款集注册中心和配置中心功能于一体的中间件。

为了快速搭建环境,本项目采用 Docker 来部署 Nacos,并通过外部 MySQL 实现数据持久化。

准备工作:

  • 已安装 Docker、Docker Compose

  • 已部署好 MySQL 容器

  • 准备好 nacos 初始化SQL文件(资料中提供)


2. Docker部署Nacos并配置MySQL持久化

2.1 初始化MySQL数据库

首先,需要在 MySQL 中创建 nacos 专用数据库,并导入官方提供的SQL脚本,初始化表结构。

操作示例(进入MySQL容器或主机执行):

复制代码
mysql -u root -p
CREATE DATABASE nacos CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
USE nacos;
SOURCE /path/to/nacos-mysql.sql;

✅ 成功后,nacos数据库中将包含多个用于注册和配置管理的表。


2.2 配置custom.env环境变量

为了让 Nacos 连接到我们的 MySQL,需要准备好 custom.env 文件,内容如下:

复制代码
# 启动模式
MODE=standalone

# 优先使用hostname进行服务注册
PREFER_HOST_MODE=hostname

# 数据源配置
SPRING_DATASOURCE_PLATFORM=mysql
MYSQL_SERVICE_HOST=192.168.100.100
MYSQL_SERVICE_PORT=3306
MYSQL_SERVICE_DB_NAME=nacos
MYSQL_SERVICE_USER=root
MYSQL_SERVICE_PASSWORD=123456
MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai

注意事项:

  • MYSQL_SERVICE_HOST 需要填写你的 宿主机IP地址(示例用 192.168.100.100)。

  • 保证你的 MySQL 可以被外部容器访问,且 nacos库已初始化完成。


2.3 上传nacos目录至虚拟机

将资料中的 nacos/ 文件夹(含 custom.env)上传到你的虚拟机 /root/ 目录:

复制代码
scp -r nacos/ root@192.168.100.100:/root/

2.4 通过Docker运行Nacos

进入 /root 目录,执行Docker命令启动Nacos容器:

复制代码
docker run -d \
--name nacos \
--env-file ./nacos/custom.env \
-p 8848:8848 \
-p 9848:9848 \
-p 9849:9849 \
--restart=always \
nacos/nacos-server:v2.1.0-slim

参数说明:

  • --env-file:加载环境变量配置文件。

  • -p:端口映射,8848是控制台端口。

  • --restart=always:容器异常自动重启。


2.5 验证Nacos部署

浏览器访问:

复制代码
http://192.168.100.100:8848/nacos/

首次访问会跳转到登录界面:

  • 账号:nacos

  • 密码:nacos

✅ 登录成功后,进入Nacos控制台!


3. 微服务注册到Nacos(item-service示例)

item-service 微服务为例,演示如何注册到Nacos。


3.1 引入Nacos Discovery依赖

pom.xml 添加依赖:

复制代码
<!-- Nacos 服务注册与发现 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

3.2 配置application.yml

复制代码
spring:
  application:
    name: item-service
  cloud:
    nacos:
      server-addr: 192.168.100.100:8848
server:
  port: 8081

3.3 启动多个实例模拟负载均衡

分别启动 item-service 的两个实例,可以分别配置端口为 8081 和 8082。

启动后,在 Nacos 控制台可以看到 item-service 服务的两个实例注册成功。


4. 微服务服务发现与调用(cart-service示例)

演示 cart-service 如何通过 Nacos 发现并调用 item-service。


4.1 引入依赖

cart-servicepom.xml 中添加:

复制代码
<!-- Nacos 服务注册与发现 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

4.2 配置application.yml

复制代码
spring:
  cloud:
    nacos:
      server-addr: 192.168.100.100:8848
server:
  port: 8085

4.3 使用DiscoveryClient进行服务发现

在 cart-service 中注入 DiscoveryClient

复制代码
@Autowired
private DiscoveryClient discoveryClient;

实现基于服务名的动态调用:

复制代码
List<ServiceInstance> instances = discoveryClient.getInstances("item-service");
ServiceInstance instance = instances.get(new Random().nextInt(instances.size()));
String url = instance.getUri() + "/items";
RestTemplate restTemplate = new RestTemplate();
String response = restTemplate.getForObject(url, String.class);

✅ 这样每次调用可以随机访问 item-service 的不同实例,实现简单的负载均衡。


4.4 测试服务调用

使用 Postman 或 Swagger 发起请求,可以观察到负载均衡正常生效,分别路由到不同的 item-service 实例。


5. 小结

本文完整介绍了:

  • 如何使用 Docker 部署 Nacos 并连接外部 MySQL。

  • 如何让微服务注册到 Nacos。

  • 如何通过 DiscoveryClient 发现服务并实现简单负载均衡调用。

✅ 通过本教程,可以初步搭建起基于 Nacos 的微服务注册与发现体系!

相关推荐
EverydayJoy^v^4 小时前
RH134学习进程——十二.运行容器(1)
linux·运维·容器
岁岁种桃花儿4 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
java_logo4 小时前
OpenProject Docker 容器化部署指南:从快速启动到生产环境配置
docker·容器·openproject·openproject部署·openproject部署手册·openproject部署方案·openproject部署教程
曦云沐6 小时前
【避坑指南】Ubuntu更新报错“Repository is not signed”的快速修复
linux·ubuntu·docker
Exquisite.7 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
cg_ssh7 小时前
Docker 下启动 Nacos 3.1.1 单机模式
运维·docker·容器
修己xj7 小时前
使用 Docker 部署 SQL Server 并导入 .mdb 文件的完整指南
运维·docker·容器
踩坑小念8 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶8 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok9 小时前
MySQL的常用数据类型
数据库·mysql