從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
: 數據庫用戶名。
創(chuàng)建新的PG容器
準備好備份文件之后,然后,停止老的PG容器,創(chuàng)建新的PG容器。
# 停止老的PG容器 docker stop postgres # 創(chuàng)建新的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部署的PostgreSQL數據庫
注:系統(tǒng)必須已安裝docker和docker-compose
一、PostgreSQL備份腳本
1. 備份腳本
# vi /opt/postgresql/conf/backup/pg_backup.sh #!/bin/bash # 設置數據庫連接參數 DB_HOST="localhost" DB_PORT="5432" DB_NAME="PGDB" DB_USER="root" DB_PASS="Admin@123" # 設置備份目錄 BACKUP_DIR="/mnt" # 獲取當前時間戳 TIMESTAMP=$(date +"%Y%m%d%H%M%S") # 設置備份文件名 BACKUP_FILE="$BACKUP_DIR/backup_$DB_NAME_$TIMESTAMP.sql" # 使用 pg_dump 命令備份數據庫 pg_dump -h $DB_HOST -p $DB_PORT -U $DB_USER -d $DB_NAME -Fc -b -v -f "$BACKUP_FILE" # 檢查備份是否成功,并導出備份日志 if [ $? -eq 0 ]; then echo "$TIMESTAMP Backup completed successfully: $BACKUP_FILE" >> /mnt/pg_backup.log else echo "$TIMESTAMP Backup failed." >> /mnt/pg_backuo.log fi # 檢查并刪除十天前的備份文件 find "$BACKUP_DIR" -type f -name "$DB_NAME_*.sql" -mtime +10 -exec rm {} \; echo "$TIMESTAMP Backup completed and old backups cleaned up." >> /mnt/pg_backup.log
2.添加執(zhí)行權限
chmod +x /opt/postgresql/conf/backup/pg_backup.sh
二、 部署PostgreSQL
1. 使用docker-compos部署PG
# vi /opt/postgresql version: "3" services: postgresql: image: postgres:16.3-alpine restart: always privileged: true environment: POSTGRES_USER: root POSTGRES_PASSWORD: Admin@123 POSTGRES_DB: PGDB ports: - 5432:5432 volumes: - ./conf/postgres/data:/var/lib/postgresql/data - ./conf/backup:/mnt #備份腳本和備份文件存放目錄
2. 啟動PostgreSQL
# cd /opt/ postgresql # docker-compose up -d
三、 計劃任務自動備份
1. 設置計劃任務
# 每天凌晨一點自動執(zhí)行數據庫備份腳本 # crontab -l 0 1 * * * docker exec postgresql /bin/bash -c "/mnt/pg_backup.sh"
總結
到此docker遷移pg還是挺容易的。這里少了一個pg容器應當映射到持久化磁盤中,這點不要學我,以后,有機會再說吧。
到此這篇關于從Docker容器中備份整個PostgreSQL的操作步驟的文章就介紹到這了,更多相關Docker備份PostgreSQL內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- PostgreSQL Docker部署+SpringBoot集成方式
- Docker環(huán)境實現PostgreSQL自動備份的流程步驟
- Docker安裝PostgreSQL數據庫的詳細步驟
- 使用docker compose啟動postgresql的示例代碼
- 在docker上部署postgreSQL主從的超詳細步驟
- Docker修改Postgresql密碼的方法詳解
- Docker如何安裝PostgreSQL
- 如何使用Dockerfile創(chuàng)建PostgreSQL數據庫
- docker容器中登陸并操作postgresql的實現
- 一步步教你用docker部署postgreSQL數據庫
- Docker部署postgresql的方法實現
相關文章
IDEA通過Docker插件部署SpringBoot項目的過程詳解
在idea中如何通過Docker插件部署SpringBoot項目呢?很多朋友在配置過程中走了很多誤區(qū),今天小編給大家分享一篇教程關于IDEA通過Docker插件部署SpringBoot項目的過程,感興趣的朋友一起看看吧2021-11-11