昨天尝试把原有的 mysql 数据库从测试服务器上迁移到 docker 服务器上,折腾了挺久,记录一下最后成功的步骤:
# 拉取镜像(默认用了最新的 8.0 版本)
docker pull mysql
# 启动服务
docker run --name "mysql" -e "MYSQL_ROOT_PASSWORD=root" -p "3306:3306" -v "/opt/mysql_data_docker/data:/var/lib/mysql" -d mysql
#进入对应容器
docker exec -it mysql bash
# 进入 mysql 服务
mysql -u root -p"autotest123456"
# 修改默认密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'autotest123456';
踩坑过程:
查找网上很多资料,都说是 centos 服务器上的权限管理问题导致的,也有很多人分享了各种解决方式。 但尝试了各种方法,都无法解决。
最终解决:
其实修改一下搭载命令的格式,把路径都改为绝对路径就解决了问题。
原因是原来的启动命令中由于对参数加双引号,导致部分参数识别错乱。 全部加上双引号之后解决了。
解决方法: 原因是由于 MySQL8.0 之后的加密规则为 caching_sha2_password,将加密规则改成 mysql_native_password 后解决:
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
到这里终于部署成功,剩下把数据库从原服务器备份,导入到新的 docker mysql 服务器就 OK 了。