系统服务、Docker 容器、宝塔自带,三个mysql怎么分辨
当我在阿里云服务安装了宝塔,安装了docker,又不小心在docker上安装了mysql,又在宝塔上启动了mysql,此时
使用命令查看系统上的mysql
bash
systemctl status mysql

使用命令
bash
docker ps

宝塔也有mysql

按照宝塔的mysql用户名密码连接,发现连接不了
一、快速定位:当前是哪个 MySQL 在提供服务?
执行这个命令,查看 3306 端口 被谁占用:
bash
sudo netstat -tlnp | grep 3306

输出示例及解读:
| 输出 示例 | 说明 |
|---|---|
| mysqld | 系统 MySQL 在跑 |
| docker-proxy | Docker MySQL 在跑(通过端口映射) |
| 什么都没有 | 3306 端口没有被监听,当前没有 MySQL 服务在运行 |
我的只有系统的,那就关闭系统的mysql,docker的mysql没有端口映射,删除容器后重新启动

然后使用指定的用户名密码连接即可
二、三种 MySQL 的存储位置和连接方式
| MySQL 来源 | 数据目录 | 连接方式 |
|---|---|---|
| 系统 MySQL | /var/lib/mysql | mysql -u root -p |
| 宝塔 MySQL | /www/server/data | 宝塔面板 → 数据库 → 查看端口/密码 |
| Docker MySQL | Docker 卷或容器内 | docker exec -it 容器名 mysql -u root -p |
三、为什么用用户名和密码连不上?
情况1:3306 端口没有被监听
原因:三个 MySQL 都装了,但可能一个都没启动。
解决:选择一个启动即可。
情况2:Docker MySQL 没有做端口映射
-
原因:Docker 容器内部有 MySQL,但没把 3306 端口映射到宿主机。
-
检查:执行 docker ps,查看 PORTS 列:
-
显示 0.0.0.0:3306->3306/tcp → 端口已映射 ✅
-
显示 3306/tcp 或没有端口 → 端口未映射 ❌
-
-
解决:删除容器,用带端口映射的方式重新创建:
-
docker run -d --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:8.0
四、建议:只保留一个 MySQL
✅ 方案一:只用 Docker MySQL(推荐
bash
# 1. 停止系统 MySQL
sudo systemctl stop mysql
sudo systemctl disable mysql
# 2. 停止宝塔 MySQL
/etc/init.d/mysqld stop
# 3. 确保 Docker MySQL 正常运行且端口已映射
docker start mysql容器名
# 4. 连接测试
mysql -h 127.0.0.1 -P 3306 -u root -p
✅ 方案二:只用宝塔 MySQL
bash
# 1. 停止系统 MySQL
sudo systemctl stop mysql
sudo systemctl disable mysql
# 2. 停止 Docker MySQL
docker stop mysql容器名
# 3. 确保宝塔 MySQL 启动
/etc/init.d/mysqld start
✅ 方案三:只用系统 MySQL
bash
# 1. 停止 Docker MySQL
docker stop mysql容器名
# 2. 停止宝塔 MySQL
/etc/init.d/mysqld stop
# 3. 启动系统 MySQL
sudo systemctl start mysql
五、快速诊断命令汇总
bash
# 1. 查看端口占用(核心)
sudo netstat -tlnp | grep 3306
# 2. 查看 Docker 容器
docker ps | grep mysql
# 3. 查看系统服务状态
systemctl status mysql
systemctl status mysqld
# 4. 查看宝塔 MySQL 状态
/etc/init.d/mysqld status
# 5. 测试连接
mysql -h 127.0.0.1 -P 3306 -u root -p