exec db docker from A to B

A服务器的硬盘将满,将数据库从A服务器拷贝到B服务器

df-h 查看数据库所在硬盘已经使用96%,欲将数据库迁移至服务器b的/nfs/quant

注意点:当前cpu所剩无几,不能gzip,硬盘也没有多余空间用于压缩docker,最好的办法就是直接将docker exec 到nfs/quant

首先检查nfs/quant的写入权限,当然不检查的话,后面无法写入,自然就会去修改了,

复制代码
chown = change owner(修改所有者)
chmod = change mode(修改权限)
chgrp = change group(修改组)

使用tmux开一个后台可运行的窗口,保证你在关闭或着断线的情况下可以一直运行命令,不至于中途退出

复制代码
docker exec your-db pg_dumpall -U yourusername > /nfs/quant/nameyouwant_${DATE}.sql

将your-db yourusername nameyouwant 替换成你自己的,DATE=$(date +%Y%m%d_%H%M%S) 在这之前运行一下,方便记录是什么时候迁移的,备份数据也是可以如此使用。

然后去B服务器,监控,查看数据迁移大小的变化

复制代码
watch -n 2 "ls -lh /nfs/quant/nameyouwant-*.sql 2>/dev/null"

上面完成之后,备份image,使用docker ps查看image, 替换yourimage nameyouwant 运行迁移镜像的命令

复制代码
docker save yourimage -o /nfs/quant/nameyouwant-image-${DATE}.tar

完成后,导出配置

复制代码
docker inspect your-db > /nfs/quant/nameyouwant-config-${DATE}.json

ls -lh /nfs/quant/nameyouwant-*${DATE}*

查看所有文件是否已经完成迁移,已经完成迁移。

相关推荐
lichenyang4536 小时前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4536 小时前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4536 小时前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4536 小时前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库