【图文实操教程】如何备份Docker容器中的PostgreSQL数据

目录

  • 一、前言
  • 二、操作步骤
    • [1. 查看并确定目标容器](#1. 查看并确定目标容器)
    • [2. 进入容器](#2. 进入容器)
    • [3. 执行备份命令](#3. 执行备份命令)
    • [4. 退出容器并复制备份文件](#4. 退出容器并复制备份文件)

一、前言

现在docker容器很方便,可以一键部署项目,但是方便部署的同时,也给运维带来了麻烦,docker中的pgsql数据,如何进行备份呢

二、操作步骤

1. 查看并确定目标容器

使用docker ps命令查看当前运行的容器列表,找到运行PostgreSQL的容器ID或名称。通常,PostgreSQL容器可以通过其监听的端口(默认为5432)来识别

bash 复制代码
docker ps

如图,我的pgsql的镜像id是 28fe3d7203e5

2. 进入容器

使用docker exec命令进入PostgreSQL容器。这里需要以root用户身份或使用具有足够权限的用户进入,以便执行备份命令

bash 复制代码
docker exec -u root -it 容器名或容器ID /bin/bash

举例

bash 复制代码
docker exec -u root -it 28fe3d7203e5 /bin/bash

3. 执行备份命令

在容器内部,使用pg_dump命令来备份数据库

bash 复制代码
pg_dump -h localhost -p 5432 -U 用户名 -d 数据库名 > 备份文件名.sql

-h 指定数据库服务器的主机名,这里因为是Docker容器内部,所以通常是localhost。

-p 指定数据库服务器的端口,PostgreSQL默认端口是5432。

-U 指定连接数据库的用户名。

-d 指定要备份的数据库名。将备份结果重定向到文件。

举例

bash 复制代码
pg_dump -h localhost -p 5432 -U docmost -d docmost > /var/lib/postgresql/data/backup.sql
bash 复制代码
小小鱼儿小小林
原文链接:https://yujianlin.blog.csdn.net/article/details/141793124

4. 退出容器并复制备份文件

完成备份后,使用exit命令退出容器。然后,使用docker cp命令将备份文件从容器内复制到宿主机上

bash 复制代码
exit
bash 复制代码
docker cp 容器名或容器ID:/路径/backup.sql /宿主机/目标/路径/

举例

bash 复制代码
docker cp 28fe3d7203e5:/var/lib/postgresql/data/backup.sql /home/vdc/tools/docmost/docker/docmost/

注意,这里的冒号: 两边不要留空,如果留空的话就会报异常

"docker cp" requires exactly 2 arguments.

See 'docker cp --help'.

Usage: docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-

docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH

Copy files/folders between a container and the local filesystem

正确的格式就会输出 Successfully,如图

然后,你们可以xshell登录看一下当前目录或者打开 XFTP工具看一下是否已经备份成sql文件了

相关推荐
树℡独6 小时前
ns-3仿真之应用层(五)
服务器·网络·tcp/ip·ns3
小小管写大大码7 小时前
如何让vscode变得更智能?vscode接入claude实现自动编程
运维·ide·vscode·自动化·编辑器·ai编程·腾讯云ai代码助手
zhang133830890757 小时前
CG-09H 超声波风速风向传感器 加热型 ABS材质 重量轻 没有机械部件
大数据·运维·网络·人工智能·自动化
a41324477 小时前
ubuntu 25 安装vllm
linux·服务器·ubuntu·vllm
Configure-Handler8 小时前
buildroot System configuration
java·服务器·数据库
津津有味道8 小时前
易语言TCP服务端接收刷卡数据并向客户端读卡器发送指令
服务器·网络协议·tcp·易语言
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.9 小时前
Keepalived VIP迁移邮件告警配置指南
运维·服务器·笔记
物联网软硬件开发-轨物科技9 小时前
【轨物洞见】告别“被动维修”!预测性运维如何重塑老旧电站的资产价值?
运维·人工智能
程序员允诺9 小时前
[DevOps实战] 彻底解决依赖地狱:如何编译全静态、可移植的 Xorriso 工具
运维·devops
酣大智9 小时前
接口模式参数
运维·网络·网络协议·tcp/ip