Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移
1.备份旧的MySQL5.7的数据
记得首先要备份旧的数据,防止升级失败导致数据丢失。备份的方式有两种,一种是在宿主机直接执行导出命令,另外一种是先进入Docker环境下进行操作。主要的导出命令如下:
#方式一,直接在宿主机器进行数据备份 #0df568是docker的id;-uroot-p123456是用户名和密码;dbAdbB是要备份的数据,--databases后面可以接多个数据库名,导出的sql到/root/all-databases3306.sql dockerexec-it0df568mysqldump-uroot-p123456--databasesdbAdbB>/root/all-databases3306.sql #======================================================================================================================================================== #方式二,先进入到docker在执行mysqldump,然后再将导出的sql拷贝到宿主 #先进入docker dockerexec-it0df568/bin/bash #可选的 source/etc/profile #执行导出命令 mysqldump-uroot-p123456--databasesdbAdbB>/root/all-databases3306.sql #拷贝到宿主机器 #退出Docker,执行exit命令 exit #此时,已经在宿主的环境,执行拷贝命令,将sql文件从docker红拷贝出来 dockercp0df568:/root/all-databases3306.sql/root/all-databases3306.sql
2.拉取MySQL8.0.13的镜像,完成安装
拉取和安装MySQL其实可以完全参考官网即可。参考网址:https://hub.docker.com/r/mysql/mysql-server/,这里再简单的描述一下安装的过程。
2.1拉取镜像到本地
运行下面的命令即可拉取最新的MySQL镜像
dockerpullmysql/mysql-server:lastest
拉取指定的MySQL镜像
#tag就是填写你要的版本号,例如你想要的MySQL8.0.13那么tag就是8.0.13,则执行:dockerpullmysql/mysql-server:8.0.13
dockerpullmysql/mysql-server:tag
可以使用dockerimages查看你拉取下来的进行。
2.2运行MySQL8.0.13镜像
运行指定的MySQL8.0.13的Docker镜像,我们在2.1步骤已经拉取了指定的镜像下来,那么可以通过dockerimages查看到本地的Docker镜像,得到镜像的ID和名字。接下来运行下列的命令运行MySQL8.0.13的Docker镜像:
#--name指定运行启动后的名字-e指定docker里的环境变量-v分区或者是目录映射,docker的程序数据映射到宿主的指定位置-p指定宿主到docker程序的端口映射-d指定镜像的版本。 dockerrun--name=mysql8.0-eMYSQL_ROOT_PASSWORD=123456-v/root/dockerdata/mysql8.0/data:/var/lib/mysql-p3307:3306-ditmysql/mysql-server:8.0.13
查看是否在运行
#执行下列的命令 dockerps
3.升级到MySQL8.X之后的一些问题
升级MySQL8.x后,远程连接无法连接,这样很不方便,需要进行修改。主要包括下面两方面的配置:
3.1提供远程访问
修改用户为@'%',%代表所有的主机都可以连接,命令如下:
#先root登录到数据库,执行下列的命令 #a.使用msyql usemysql; #b.然后执行授权 GRANTALLPRIVILEGESON.TO'root'@'%'IDENTIFIEDBY'123456' #c.一定要刷新权限(重新加载),否则需要重启MySQL才能生效 FLUSHPRIVILEGES;
3.2更改连接的密码校验方式
MySQL8.X的加密方式是caching_sha2_password,caching_sha2_password加密方式在远程访问时候不支持,所以需要改成:mysql_native_password
#a.修改指定的用户 ALTERUSER'root'@'%'IDENTIFIEDWITHmysql_native_passwordBY'123456'; #b.一定要刷新权限(重新加载),否则需要重启MySQL才能生效 FLUSHPRIVILEGES;
4.导入数据到新的MySQL中
导入数据,我采用的方式是先将数据库备份文件拷贝进新的Docker,然后再执行导入命令。命令如下:
#拷贝备份的文件到docker中 dockercp/root/all-databases3306.sql3sfsdf:/root/all-databases3306.sql #先进入docker环境,然后导入到数据库 dockerexec-itxxx/bin/bash mysql-uroot-p5.参考文档
https://hub.docker.com/r/mysql/mysql-server/
https://bugs.mysql.com/bug.php?id=92675
总结
以上所述是小编给大家介绍的Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!