
justb4/pgbackupDocker PG Backup是一个Docker容器,用于为其网络中所有带有标签"pgbackup.enable=true"的PostgreSQL/PostGIS容器执行自动定时备份。它支持多种PostgreSQL/PostGIS镜像,默认每日23:00创建备份,文件按容器名/年/月的目录结构组织,可自定义备份计划。适用于需要自动备份多个PostgreSQL/PostGIS容器的Docker环境,如开发、测试和生产环境。
"pgbackup.enable=true"标签的PostgreSQL容器容器名/年/月/<容器名>-ymd-hm.sql.gz路径组织postgres:<version>-alpine镜像,体积更小| 变量名 | 描述 | 默认值 |
|---|---|---|
PGB_SCHEDULE | crontab格式的备份调度表达式 | 0 23 * * *(每日23:00) |
bashdocker pull justb4/pgbackup:11
建议使用带标签的镜像,避免
latest标签可能带来的兼容性问题,应使用与目标数据库相同或更高版本的镜像。
bash# 克隆仓库 git clone git://github.com/justb4/docker-pgbackup cd docker-pgbackup # 构建镜像 docker build -t justb4/pgbackup .
bashdocker run --name="pgbackup" \ -v /path/to/backup:/backup \ -v /var/run/docker.sock:/var/run/docker.sock \ -d justb4/pgbackup:11
-v /path/to/backup:/backup:挂载本地目录用于存储备份文件-v /var/run/docker.sock:/var/run/docker.sock:挂载Docker socket以访问Docker APIyaml# docker-compose.yml version: "3" services: db: image: mdillon/postgis:11-alpine container_name: pg_db_11 labels: - "pgbackup.enable=true" # 启用备份标记 environment: - POSTGRES_DB=testdb - POSTGRES_USER=testuser - POSTGRES_PASSWORD=testpass dbbackup: image: justb4/pgbackup:11 container_name: pg_backup_11 volumes: - /var/run/docker.sock:/var/run/docker.sock - ./backup:/backup # 本地备份目录 environment: - PGB_SCHEDULE=*/1 * * * * # 每分钟备份一次(测试用)
启动服务:
bashdocker-compose up -d
bashdocker exec -it pgbackup /pgbackup/backup-all.sh
bashdocker exec -it pgbackup /pgbackup/backup.sh <目标容器名> <备份文件路径> # 示例 docker exec -it pgbackup /pgbackup/backup.sh pg_db_11 /backup/my_custom_backup.sql.gz
bashdocker exec -it pgbackup /pgbackup/list-backups.sh
pgbackup容器的/backup目录下(通过挂载卷共享)bash# 直接执行恢复 docker exec -it pgbackup /pgbackup/restore.sh <目标数据库容器名> <备份文件路径> # 示例 docker exec -it pgbackup /pgbackup/restore.sh pg_db_11 /backup/2023/10/pg_db_11-231015-0930.sql.gz
pgbackup.enable=true)识别目标容器,无需预先配置所有数据库凭据pgbackup容器可备份多个PostgreSQL容器postgres:<version>-alpine替代kartoza/postgismanifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务