Docker 测试服务迁移至 docker: mysql

Jerry li · November 08, 2018 · 1205 hits

昨天尝试把原有的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';

踩坑记录:

1. 搭载目录报 chown: cannot read directory '/var/lib/mysql/': Permission denied

踩坑过程:
查找网上很多资料,都说是 centos 服务器上的权限管理问题导致的,也有很多人分享了各种解决方式。 但尝试了各种方法,都无法解决。

最终解决:
其实修改一下搭载命令的格式,把路径都改为绝对路径就解决了问题。

2. 启动docker 容器后报错:mysqld: Too many arguments

原因是原来的启动命令中由于对参数加双引号,导致部分参数识别错乱。 全部加上双引号之后解决了。

3. mysql 客户端无法链接服务器,报: authentication plugin 'caching_sha2_password'

解决方法: 原因是由于MySQL8.0之后的加密规则为caching_sha2_password,将加密规则改成mysql_native_password 后解决:

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

后记

到这里终于部署成功,剩下把数据库从原服务器备份,导入到新的docker mysql 服务器就OK 了。

共收到 0 条回复 时间 点赞
Jerry li 有没有好点的 docker 解坑博客 中提及了此贴 06 Dec 09:49
需要 Sign In 后方可回复, 如果你还没有账号请点击这里 Sign Up