【排坑指南】MySQL初始化后,Nacos与微服务无法连接??

Date:2025/06/18

你好!

今天,分享一个工作中遇到的一个 MySQL 问题。在这之前都不知道是 MySQL 的问题,特离谱!

昨天和今天大多数时间都用来处理了这一个问题:《MySQL进行了数据库初始化之后,Nacos无法连接》。

介绍说明

任务是通过 K8s 私有化部署一套服务,其中依赖 MySQL 和 Nacos 中间件服务。由于是私有化部署,需要对 MySQL 中的数据进行初始化操作,就是 MySQL 启动后有我所有服务需要的数据。

MySQL 初始化的 Dockerfile 如下:

bash 复制代码
[root@host mysql-priavte-8.1.0]# cat Dockerfile
# 基础镜像:应该就是Docker Hub仓库中的MySQL-8.1.0镜像
FROM xxx.com/privatization/mysql-private:8.1.0
MAINTAINER zhencyw

# 把sql文件拷贝到/docker-entrypoint-initdb.d/目录下,以便启动时自动执行这个sql
COPY ./sql/*.sql /docker-entrypoint-initdb.d

# 拷贝mysql配置文件
COPY ./config/ /etc/mysql/

# Mysql密码
ENV MYSQL_ROOT_PASSWORD root

# 数据持久化目录
VOLUME [ "/var/lib/mysql" ]

# 端口
EXPOSE 3306

问题现象

1)使用了初始化的 MySQL 数据库之后(未进行初始化的 MySQL 未测试过),Nacos 无法连接。

从上图中,可以看到 Nacos 在启动时无法获取的数据源,这里就是连不上 MySQL。所以我通过 Navicat 进行查看我的 MySQL 中数据库和数据是否正常,结果也都是有的。这里奇怪的一点是,Navicat 能连接上我的 MySQL 为啥 Nacos 就连不上呢?(到现在也不知原因)

就因为这一点我对 MySQL 未有丝毫的怀疑是它的问题,谁知道结果压根就是 MySQL 的问题。基于前者,导致我对 Naocs 进行各种测试验证,Nacos 启动时行时不行,也切换了3个 Naocs 版本与部署方式(helm、operator)进行测试,都报 Nacos 未进行设置数据源。测试无果。

2)内部项目的微服务进行连接这个初始化的 MySQL 也是连接不上。。这里就能看出是 MySQL 的问题了,不过我是在偶然间发现是 MySQL 问题时才去进行这个测试的。。

MySQL 进行远程连接后这个数据库身份验证方式还是caching_sha2_password这个。但是服务未报错,服务登录成功了。

处理方法

1)通过 Navicat 连接工具,进行重新创建导入 nacos 库和数据,重启 Nacos 后能启动。但由于不满足我脚本一键启动的条件,所以还得找找其他原因。

2)最终处理方法:MySQL 首次启动后需要进行远程连接一次 MySQL,否则 Naocs 与微服务连不上 MySQL,原因不知。。。不知道是不是MySQL配置问题了。


最后:处理方法很简单,发现这个问题真不容易。。。

关注我的gzh,获取更多运维经验!!

END

相关推荐
Zh&&Li1 分钟前
保姆级安装AI全自动渗透工具(pentestswarm)
linux·运维·服务器·人工智能
木雷坞2 分钟前
Playwright MCP Docker 部署:mcr 镜像、浏览器工具和权限配置
运维·docker·容器·mcp
江湖有缘11 分钟前
Docker一键部署open-resume简历生成器
运维·docker·容器
这个DBA有点耶12 分钟前
时序数据库选型:吞吐、压缩与查询延迟的均衡之术
数据库·sql·架构·时序数据库·dba
snow@li13 分钟前
数据库:MySQL vs PostgreSQL 详尽对比(2026版)
java·mysql·postgresql
luck_bor15 分钟前
数据库简介
数据库·oracle
沉在嵌入式的鱼18 分钟前
Jetson系列集成第三方库和应用程序到镜像方案
运维·服务器
hikktn26 分钟前
Oracle批量UPDATE空值覆盖陷阱:CASE WHEN优雅防御方案【宗申集团】
数据库·oracle
Han_han91929 分钟前
数据库基本操作:
数据库
weixin_6042366733 分钟前
华三 二层交换机 企业完整正式版配置
运维·网络·华为·华为交换机命令