直接在虚拟机里装 MySQL 和物理机没区别,关键看你要不要容器化
如果你只是想跑个 MySQL 供开发或测试用,
apt install mysql-server(Ubuntu/Debian)或
yum install mysql-server(CentOS 7)就能搞定。但“虚拟化部署”这个词容易让人混淆——它可能指传统虚拟机(VM)里的 MySQL,也可能误指容器(Docker)。先明确:VM 里装 MySQL 就是常规 Linux 安装,不涉及特殊“虚拟化适配”。
VM 中安装 MySQL 后必须改的三件事
默认配置在虚拟机里大概率连不上、存不了数据、启动失败。常见问题不是安装失败,而是后续访问被拦住:
bind-address默认是
127.0.0.1,导致宿主机或其他 VM 无法连接 → 改成
0.0.0.0或具体网卡 IP MySQL 8.0+ 默认用
caching_sha2_password插件,老客户端(如某些 Python MySQL 驱动、Navicat 旧版)会报
Authentication plugin 'caching_sha2_password' cannot be loaded→ 创建用户时指定
mysql_native_password
sudo systemctl start mysqld失败?检查
/var/log/mysqld.log,常见原因是磁盘空间不足或
/var/lib/mysql权限不对(尤其你手动挂载了新磁盘后没 chown mysql:mysql)
Docker 方式更接近“虚拟化部署”的本意,但别直接 run 官方镜像
如果真想用轻量、可复现的方式部署,Docker 是更贴切的“虚拟化”实践。但注意:
docker run -d -p 3306:3306 mysql:8.0会丢数据——容器删了,数据库就没了。
正确做法是绑定宿主机目录或使用命名卷:
docker run -d \ --name mysql-dev \ -v /mydata/mysql:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ -e MYSQL_DATABASE=testdb \ -p 3306:3306 \ -d mysql:8.0
⚠️ 注意:
/mydata/mysql目录必须提前
chown -R 999:999 /mydata/mysql(MySQL 容器内用用户 ID 999 运行),否则启动失败且日志只显示
mysqld: Can't create/write to file。
跨 VM 访问 MySQL 时防火墙和网络模式最常踩坑
宿主机 ping 得通 VM,但连不上 3306?别急着查 MySQL 配置,先看这两处:
VM 的防火墙是否放行 3306:Ubuntu 上是sudo ufw allow 3306;CentOS 7 是
sudo firewall-cmd --permanent --add-port=3306/tcp && sudo firewall-cmd --reloadVM 网络模式是不是 NAT:如果是,宿主机要通过 VM 的 IP 连(比如
192.168.122.10),不能用
localhost;如果是桥接(Bridged),确保 VM 和宿主机在同一子网,且没被路由器隔离 MySQL 用户权限是否包含远程来源:创建用户得用
CREATE USER 'dev'@'%' IDENTIFIED WITH mysql_native_password BY 'pwd';,而不是
'dev'@'localhost'
这些点串起来才构成一个真正可用的虚拟机 MySQL 环境。很多人卡在某一个环节反复重装,其实跟 MySQL 本身关系不大。
