当前位置: 首页 > news >正文

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

目录

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

一、 简介

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

二、操作流程

2.1 进入mysql容器

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

docker exec -it mysql-old /bin/bash

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

2.2 导出 MySQL 数据

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

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 服务:

services:mysql:image: mysql:8.4.0container_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: rootTZ: Asia/Shanghai   # 设置时区,例如亚洲/上海restart: alwaysdeploy:resources:limits: # 设置合理的资源限制cpus: '0.5' # 限制容器使用半核 CPU 资源memory: 512M # 限制容器使用最多 512MB 内存

2.5 启动新的 Docker 容器

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

2.6 导入数据到新的容器

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

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;

连接时如果出现:

❯ 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 配置来管理容器网络。
  • 实施定期备份策略,保障数据安全。

四、写在后面

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

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

http://www.lryc.cn/news/382220.html

相关文章:

  • 猫头虎 分享已解决Error || API Rate Limits: HTTP 429 Too Many Requests
  • 开发一个python工具,pdf转图片,并且截成单个图片,然后修整没用的白边及循环遍历文件夹全量压缩图片
  • 【数据结构与算法 经典例题】使用栈实现队列(图文详解)
  • 不知大家信不信,竟有这么巧的事,我领导的老婆,竟然是我老婆的下属,我在想要不要利用下这层关系,改善下领导对我的态度,领导怕老婆
  • 使用pkg -r 命令选项向jail虚拟子系统里安装软件@FreeBSD
  • Go语言开发框架GoFly已集成数据可视化大屏开发功能,让开发者只专注业务开发,本文指导大家如何使用
  • PR模板 | RGB特效视频标题模板Titles | MOGRT
  • python替换文件内容
  • SD-WAN是什么?它有哪些应用领域?
  • PHP-CGI的漏洞(CVE-2024-4577)
  • 人工智能前沿讲座——AIGC
  • CCF 第33次CCF计算机软件能力认证第二题
  • python 学习积累
  • ARM day1总结
  • 套路化编程:C# ListView 保存、恢复列宽度
  • python单元测试
  • 华为---静态路由-浮动静态路由及负载均衡(二)
  • Maven deploy上传远程私服失败
  • 通天星CMSV6车载定位监控平台 point_manage/merge SQL注入致RCE漏洞复现
  • 图像识别技术在人脸识别领域的新突破
  • iview 组件里面的(任何一个月)整月日期全部选中_iview时间轴选中有历史记录日期
  • Charles配置与API数据抓取
  • [FreeRTOS 内部实现] 信号量
  • Vue57-组件的自定义事件_解绑
  • Java启动jar设置内存分配详解
  • Feign Client超时时间设置不生效问题
  • Haproxy部署Web群集
  • C++STL梳理
  • 找出1000以内的所有的完数
  • 3110. 字符串的分数