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

从Docker容器中备份整个PostgreSQL

问题

现在需要从Docker容器中备份整个PostgreSQL后,然后,使用备份文件在另外一个pg的docker容器中恢复过来。

步骤

备份旧容器中的PG

# 登录到旧的PG容器中
docker exec -it postgres bash
# 备份数据库
pg_dumpall -c -U postgres > dump_`date +%Y-%m-%d"_"%H_%M_%S`.sql
# 退出容器
exit
# 退出容器后,复制出备份文件到主机中
docker cp postgres:/dump_2024-10-26_05_58_04.sql dump_2024-10-26_05_58_04.sql

这里主要是用pg_dumpall备份整个pg实例,具体命令解释如下:

  • -c:备份的sql文件中包含DROP语句;
  • -U: 数据库用户名。

创建新的PG容器

准备好备份文件之后,然后,停止老的PG容器,创建新的PG容器。

# 停止老的PG容器
docker stop postgres
# 创建新的PG容器
docker run --name postgres2 -e POSTGRES_PASSWORD=<密码> -p 5432:5432 -d postgres -c max_connections=800

恢复数据

# 复制备份数据文件到新PG容器中
docker cp dump_2024-10-26_05_58_04.sql postgres2:/
# 登录到新PG容器中
docker exec -it postgres2 bash
# 恢复备份数据库
psql -f dump_2024-10-26_05_58_04.sql -U postgres postgres

收尾

新pg容器没问题后,可以删除旧pg容器,然后,更名新pg容器即可。

# 删除旧pg容器
docker rm postgres
# 改名老pg容器
docker rename postgres2 postgres

总结

到此docker迁移pg还是挺容易的。这里少了一个pg容器应当映射到持久化磁盘中,这点不要学我,以后,有机会再说吧。

参考:

  • PostgreSQL 9.4.4 中文手册
  • pg_dumpall
  • How to persist and backup data of a PostgreSQL Docker container
http://www.lryc.cn/news/469444.html

相关文章:

  • 从小需求看大格局:如何用技术智慧赢得客户信任
  • 模型 支付矩阵
  • 擎创科技声明
  • 二叉树习题其六【力扣】【算法学习day.13】
  • 互联网的无形眼睛:浏览器指纹与隐私保护攻略
  • 后端技术:有哪些常见的应用场景?
  • 【Unity 安装教程】
  • C++ 二级测试卷及答案
  • Java基础(7)图书管理系统
  • 使用 Spring Boot 实现图片上传
  • 深度解析跨境支付之产品架构
  • Linux下的线程同步与死锁避免
  • 【Python爬虫实战】Selenium自动化网页操作入门指南
  • mono源码交叉编译 linux arm arm64全过程
  • 矩阵的可解性:关于Ax=b的研究
  • 10.22.2024刷华为OD C题型(三)--for循环例子
  • QT:MaintenanceTool 模块安装工具
  • 同标签实现监听LocalStorage
  • JAVA高性能缓存项目
  • 智慧农业大数据平台:智汇田园,数驭未来
  • Go语言基础教程:可变参数函数
  • 高并发场景下解决并发数据不一致
  • OpenAI GPT-o1实现方案记录与梳理
  • Excel:vba实现生成随机数
  • Python | Leetcode Python题解之第506题相对名次
  • 安全见闻(6)
  • Promise、async、await 、异步生成器的错误处理方案
  • 腾讯云:数智教育专场-学习笔记
  • Ovis: 多模态大语言模型的结构化嵌入对齐
  • python的Django的render_to_string函数和render函数模板的使用