Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移
⽬录
1.备份旧的MySQL5.7的数据
2.拉取MySQL8.0.13的镜像,完成安装
2.1 拉取镜像到本地
2.2 运⾏MySQL8.0.13镜像
3.升级到MySQL8.X之后的⼀些问题
3.1 提供远程访问
3.2 更改连接的密码校验⽅式
4.导⼊数据到新的MySQL中
5.参考⽂档
1.备份旧的MySQL5.7的数据
记得⾸先要备份旧的数据,防⽌升级失败导致数据丢失。备份的⽅式有两种,⼀种是在宿主机直接执⾏导出命令,另外⼀种是先进⼊Docker环境下进⾏操作。主要的导出命
令如下:
#⽅式⼀,直接在宿主机器进⾏数据备份
# 0df568 是docker的id ;-uroot -p123456 是⽤户名和密码;dbA dbB是要备份的数据,--databases 后⾯可以接多个数据库名,导出的sql到/root/all-databases3306.sql
docker exec -it 0df568 mysqldump -uroot -p123456 --databases dbA dbB > /root/all-databases3306.sql
#======================================================================================================================================================== #⽅式⼆,先进⼊到docker在执⾏mysqldump,然后再将导出的sql拷贝到宿主
#先进⼊docker
docker exec -it 0df568 /bin/bash
#可选的
source /etc/profile
#执⾏导出命令
mysqldump -uroot -p123456 --databases dbA dbB > /root/all-databases3306.sql
#拷贝到宿主机器
#退出Docker,执⾏exit命令
exit
#此时,已经在宿主的环境,执⾏拷贝命令,将sql⽂件从docker红拷贝出来
docker cp 0df568:/root/all-databases3306.sql /root/all-databases3306.sql
2.拉取MySQL8.0.13的镜像,完成安装
2.1 拉取镜像到本地
运⾏下⾯的命令即可拉取最新的MySQL镜像
docker pull mysql/mysql-server:lastest
拉取指定的MySQL镜像
#tag就是填写你要的版本号,例如你想要的MySQL8.0.13那么tag就是8.0.13,则执⾏:docker pull mysql/mysql-server:8.0.13
docker pull mysql/mysql-server:tag
可以使⽤docker images查看你拉取下来的进⾏。
2.2 运⾏MySQL8.0.13镜像
运⾏指定的MySQL8.0.13的Docker镜像,我们在2.1步骤已经拉取了指定的镜像下来,那么可以通过docker images查看到本地的Docker镜像,得到镜像的ID和名字。接下来运⾏下列的命令运⾏MySQL8.0.13的Docker镜像:
#--name指定运⾏启动后的名字 -e 指定docker⾥的环境变量 -v 分区或者是⽬录映射,docker的程序数据映射到宿主的指定位置 -p 指定宿主到docker程序的端⼝映射 -d 指定镜像的版本。
docker run --name=mysql8.0 -e MYSQL_ROOT_PASSWORD=123456 -v /root/dockerdata/mysql8.0/data:/var/lib/mysql -p 3307:3306 -dit mysql/mysql-server:8.0.13
查看是否在运⾏
# 执⾏下列的命令
docker ps
3.升级到MySQL8.X之后的⼀些问题
升级MySQL8.x后,远程连接⽆法连接,这样很不⽅便,需要进⾏修改。主要包括下⾯两⽅⾯的配置:
3.1 提供远程访问
修改⽤户为@'%',%代表所有的主机都可以连接,命令如下:
#先root登录到数据库,执⾏下列的命令
#a.使⽤msyql
use mysql;
#b.然后执⾏授权
GRANT ALL PRIVILEGES ON . TO 'root'@'%' IDENTIFIED BY '123456'
#c.⼀定要刷新权限(重新加载),否则需要重启MySQL才能⽣效
FLUSH PRIVILEGES;
3.2 更改连接的密码校验⽅式
MySQL8.X的加密⽅式是caching_sha2_password,caching_sha2_password加密⽅式在远程访问时候不⽀持,所以需要改成:mysql_native_password
# a.修改指定的⽤户
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
# b.⼀定要刷新权限(重新加载),否则需要重启MySQL才能⽣效
FLUSH PRIVILEGES;
4.导⼊数据到新的MySQL中
导⼊数据,我采⽤的⽅式是先将数据库备份⽂件拷贝进新的Docker,然后再执⾏导⼊命令。命令如下:
#拷贝备份的⽂件到docker中
docker cp /root/all-databases3306.sql 3sfsdf:/root/all-databases3306.sql
#先进⼊docker环境,然后导⼊到数据库
docker exec -it xxx /bin/bash
mysql -u root -p < /root/all-databases3306.sql
5.参考⽂档
mysql社区版国内镜像下载总结
以上所述是⼩编给⼤家介绍的Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论