记得首先要备份旧的数据,防止升级失败导致数据丢失。备份的方式有两种,一种是在宿主机直接执行导出命令,另外一种是先进入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
拉取和安装MySQL其实可以完全参考官网即可。参考网址:https://hub.docker.com/r/mysql/mysql-server/ ,这里再简单的描述一下安装的过程。
运行下面的命令即可拉取最新的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查看你拉取下来的进行。
运行指定的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
升级MySQL8.x后,远程连接无法连接,这样很不方便,需要进行修改。主要包括下面两方面的配置:
修改用户为@'%',%代表所有的主机都可以连接,命令如下:
#先root登录到数据库,执行下列的命令 #a.使用msyql use mysql; #b.然后执行授权 GRANT ALL PRIVILEGES ON . TO 'root'@'%' IDENTIFIED BY '123456' #c.一定要刷新权限(重新加载),否则需要重启MySQL才能生效 FLUSH PRIVILEGES;
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;
导入数据,我采用的方式是先将数据库备份文件拷贝进新的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
https://hub.docker.com/r/mysql/mysql-server/
https://bugs.mysql.com/bug.php?id=92675
总结
以上所述是小编给大家介绍的Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
主要内容:升级到 Nexus 2.x 最新版本,升级到 Nexus 3.x 最新版本与 Nexus 2.x 相比,Nexus 3.x 为我们提供了更多实用的新特性,随着 Nexus 3.x 对 Maven 的支持越来稳定,很多公司和组织都陆续将数据从 Nexus 2.x 迁移升级到 Nexus 3.x。 SonaType 官方建议我们,使用最新版本 Nexus 2.x 升级到最新版本 Nexus 3.x,并在 Nexus 升级兼容性 一文中为我们提供了各个版本 Nexus 升级
指导如何从Bootstrap v3.x升级到v4.x,重点是主要的变化,有什么新内容,以及哪些内容被移除了。 升级到 v4 Bootstrap 4 几乎是对整个项目进行了重写。其中最显著的变化都概括到了下面的内容,与以前相比,拥有了更多的具体的类以及把一些有关的部分变成了相关的组件。 当心!它在 flux 中工作的时候和在 v4 alphas 进程中工作是一致的。只有当它在不完整的情况下,我们才会
根据Hazelcast官方文档,从版本3.8开始支持滚动升级。 如果我的服务器版本是3.5,是否有办法创建一个成功的集群,其中新的盒子运行较新版本的Hazelcast? 天真地升级到3.6。*导致了两个不同的集群(旧的盒子仍然运行3.5,而另一个新的盒子运行3.6,显然没有数据,因为它永远无法与现有的盒子接触)。 我的部署过程如下: 创建一组新框 我的想法是在磁盘/数据库上存储快照,并在推出时从数
升级后消息声明: 升级到Android Studio到版本>=0.8.0后也会出现同样的问题
迁移 Navicat Data Modeler 到新的电脑 在 Navicat Data Modeler,选择“Navicat Data Modeler”->“注册”。 【永久许可证】点击“取消激活”以在线取消激活许可证密钥。 【订阅方案】点击“退出”以退出你的 Navicat ID。 在现有的电脑解除安装 Navicat Data Modeler。 在新的电脑重新安装 Navicat Data
迁移 Navicat Data Modeler 到新的电脑 在 Navicat Data Modeler,选择“帮助”->“注册”。 【永久许可证】点击“取消激活”以在线取消激活许可证密钥。 【订阅方案】点击“退出”以退出你的 Navicat ID。 在现有的电脑解除安装 Navicat Data Modeler。 在新的电脑重新安装 Navicat Data Modeler。 升级 Navica