Docker 中 MySQL 迁移策略(单节点)

目录

    • [一、 简介](#一、 简介)
    • 二、操作流程
      • [2.1 进入mysql容器](#2.1 进入mysql容器)
      • [2.2 导出 MySQL 数据](#2.2 导出 MySQL 数据)
      • [2.3. 将导出的文件复制到宿主机](#2.3. 将导出的文件复制到宿主机)
      • [2.4 创建 Docker Compose 配置](#2.4 创建 Docker Compose 配置)
      • [2.5 启动新的 Docker 容器](#2.5 启动新的 Docker 容器)
      • [2.6 导入数据到新的容器](#2.6 导入数据到新的容器)
      • [2.7 验证数据](#2.7 验证数据)
      • [2.8 删除旧的容器(删除操作需慎重)](#2.8 删除旧的容器(删除操作需慎重))
    • 三、推荐配置
    • 四、写在后面

一、 简介

本人发现自己Docker中Mysql的时区不对,导致每次连接数据库都需要设置时区,所以考虑进行数据库迁移,重新搭建一个正确时间的数据库。

二、操作流程

2.1 进入mysql容器

要进入运行中的 MySQL 容器,可以使用以下命令:

bash 复制代码
docker exec -it mysql-old /bin/bash

这里的 mysql-old 是你原来容器的名

2.2 导出 MySQL 数据

在容器内部,使用 mysqldump 工具导出所有数据库:

bash 复制代码
mysqldump -u root -p --all-databases > /tmp/alldb.sql

2.3. 将导出的文件复制到宿主机

/tmp/alldb.sql 文件从容器复制到宿主机的指定路径:

复制代码
docker cp mysql-old:/tmp/alldb.sql Docker/mysql

2.4 创建 Docker Compose 配置

编写 docker-compose.yml 文件,配置新的 MySQL 服务:

yml 复制代码
services:
  mysql:
    image: mysql:8.4.0
    container_name: mysql-docker # 设置容器名字
    ports: # 添加端口映射
      - "3306:3306"
    volumes:
      - /Users/siyuan/Docker/mysql/data:/var/lib/mysql  # 数据卷
      - /Users/siyuan/Docker/mysql/conf:/etc/mysql/conf.d  # 配置卷
      - /Users/siyuan/Docker/mysql/logs:/var/log/mysql  # 日志卷
    environment:
      MYSQL_ROOT_PASSWORD: root
      TZ: Asia/Shanghai   # 设置时区,例如亚洲/上海
    restart: always
    deploy:
      resources:
        limits: # 设置合理的资源限制
          cpus: '0.5' # 限制容器使用半核 CPU 资源
          memory: 512M # 限制容器使用最多 512MB 内存

2.5 启动新的 Docker 容器

docker-compose.yml 所在路径下使用 docker-compose up -d 命令启动新的容器。

2.6 导入数据到新的容器

将宿主机上的 SQL 文件导入到新的 MySQL 容器:

bash 复制代码
docker cp Docker/mysql/alldb.sql mysql-docker:/tmp/
docker exec -i mysql-docker mysql -u root -p'root' < /tmp/alldb.sql

2.7 验证数据

登录到新的 MySQL 容器,检查数据是否成功导入:

复制代码
docker exec -it mysql-docker mysql -u root -p
SHOW DATABASES;

连接时如果出现:

bash 复制代码
❯ mysql -u root -p
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

请在连接时使用:

复制代码
mysql -u root -p -h 127.0.0.1

2.8 删除旧的容器(删除操作需慎重)

复制代码
docker stop mysql-old
docker rm mysql-old

三、推荐配置

  • 使用具体版本号的 MySQL 镜像,避免使用 latest 标签。
  • 设置合理的资源限制,避免 MySQL 服务消耗过多宿主机资源。
  • 考虑使用 Docker secrets 或环境变量文件来管理密码。
  • 确保 MySQL 用户权限设置正确,允许从宿主机 IP 地址连接。
  • 使用 Docker Compose 的 networks 配置来管理容器网络。
  • 实施定期备份策略,保障数据安全。

四、写在后面

欢迎关注,会经常记录一些工作中遇到的问题。

欢迎随时留言讨论,与君共勉,知无不答!

相关推荐
东城绝神几秒前
《Linux运维总结:基于X86_64+ARM64架构CPU使用docker-compose一键离线部署consul 1.21.5容器版集群》
linux·运维·docker·架构·consul
小醉你真好28 分钟前
17、Centos9 安装 1Panel
linux·docker·运维开发
九皇叔叔1 小时前
Linux Shell 正则表达式:从入门到实战,玩转文本匹配与处理
linux·mysql·正则表达式
Wang's Blog2 小时前
MySQL: 高并发电商场景下的数据库架构演进与性能优化实践
mysql·性能优化·数据库架构
程序新视界2 小时前
什么是MySQL JOIN查询的驱动表和被驱动表?
数据库·后端·mysql
一匹电信狗3 小时前
【MySQL】数据库的相关操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序
陈一Tender4 小时前
JavaWeb后端实战(登录认证 & 令牌技术 & 拦截器 & 过滤器)
java·开发语言·spring boot·mysql
明灯L5 小时前
《Kubernetes 集群搭建全指南:从核心概念到环境部署!》
云原生·容器·kubernetes
insight^tkk5 小时前
【Docker】记录一次使用docker部署dify网段冲突的问题
运维·人工智能·docker·ai·容器
江湖人称小鱼哥5 小时前
WSL + Docker 网络访问详解
网络·docker·容器·wsl