• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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.参考文档

    https://hub.docker.com/r/mysql/mysql-server/
    https://bugs.mysql.com/bug.php?id=92675

    总结

    以上所述是小编给大家介绍的Docker版的MySQL5.7升级到MySQL8.0.13,数据迁移,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

    上一篇:详解如何使用Docker-Compose命令
    下一篇:前端必备Nginx配置详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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