【阿里云部署服务问题指南】

系统服务、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
相关推荐
庞轩px2 小时前
第二篇:String、StringBuilder、StringBuffer深度剖析
java·字符串·stringbuilder·string·stringbuffer·字符串常量池
Rsun045512 小时前
9、Java 外观模式从入门到实战
java·开发语言·外观模式
清心歌2 小时前
TreeSet 深度解析
java·开发语言
迷藏4942 小时前
**RISC-V生态下的嵌入式开发新范式:从指令集到自定义外设的全流程实战**在当前国产化
java·python·risc-v
小松加哲2 小时前
Tomcat 核心原理全解析(含请求流转+组件源码+多应用配置)
java·tomcat·firefox
Lyyaoo.2 小时前
【JAVA基础面经】juc包(java.util.concurrent)
java·开发语言
色空大师2 小时前
【nacos下载安装】
java·linux·nacos·ubantu
weixin_704266052 小时前
spring cloud 简单了解
数据库·mysql
朱一头zcy2 小时前
Java基础复习08:IO流(File类与IO流概述、字节输入输出流、字符输入输出流、缓冲流、字符转换流、对象序列化、打印流、Commons-io包介绍)
java·笔记