没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
Docker版的版的MySQL5.7升级到升级到MySQL8.0.13,数据迁移,数据迁移
主要介绍了Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的
朋友可以参考下
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其实可以完全参考官网即可。参考网址:https://hub.docker.com/r/mysql/mysql-server/ ,这里再简单的描述一下安装的过程。
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.参考文档参考文档
资源评论
weixin_38684976
- 粉丝: 4
- 资源: 950
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 室内移动AGV服务咨询机器人proe全套技术资料100%好用.zip
- Windows 7错误代码为 0x00000124导致的蓝屏转储文件
- STM32+FreeRTOS 使用SystemView监控系统配套源码
- 三相并联型有源电力滤波器APF仿真(电压外环电流内环均为PI控制),id-iq谐波检测方法,SVPWM调制方法
- 收卷机自动换卷机(sw16可编辑+工程图)全套技术资料100%好用.zip
- Knife4j是一个集Swagger2 和 OpenAPI3为一体的增强解决方案
- 鸿蒙与原生WebH5的通信-DsBridge
- 鼎捷易飞新建账套方法步骤
- STM32+PAJ7620手势识别的智能家居控制系统识别系统程序设计
- 鼎捷易飞清楚账套内部交易数据的代码
- 实训报告-小型企业网络的搭建.docx
- 网络实践34344343443
- 基于java+springboot+mysql+微信小程序的医院核酸检测预约挂号系统 源码+数据库+论文(高分毕业设计).rar
- 基于java+ssm+mysql+微信小程序的新冠疫苗预约小程序 源码+数据库+论文(高分毕业设计).zip
- 基于Proteus的STM32 BLDC电机控制器设计与实现
- 基于java+ssm+mysql+微信小程序的新生自助报到系统 源码+数据库+论文(高分毕业设计).zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功