欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移

程序员文章站 2022-09-24 16:28:43
1.备份旧的mysql5.7的数据 记得首先要备份旧的数据,防止升级失败导致数据丢失。备份的方式有两种,一种是在宿主机直接执行导出命令,另外一种是先进入docker环境下进行操作。主...

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的镜像,完成安装

拉取和安装mysql其实可以完全参考官网即可。参考网址: ,这里再简单的描述一下安装的过程。

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.参考文档



总结

以上所述是小编给大家介绍的docker版的mysql5.7升级到mysql8.0.13,数据迁移,希望对大家有所帮助