Shell脚本一键逻辑备份PostgreSQL数据库多个指定数据库

  1. 原始脚本

    #!/bin/bash

    多数据库备份示例

    数据库连接配置

    export PGPASSWORD="fYhuqwuiooo="
    DB_HOST="10.10.88.180"
    DB_PORT="5432"
    DB_USER="lmzf"

    要备份的数据库列表

    DATABASES=("pg_database1","pg_database2")
    BACKUP_DIR="/path/to/backup"
    DATE=$(date +"%Y%m%d")

    for DB_NAME in "{DATABASES[@]}"; do BACKUP_FILE="{BACKUP_DIR}/{DB_NAME}_{DATE}.dump"
    echo "(date) - 开始备份数据库: {DB_NAME}" >> ${BACKUP_DIR}/backup.log

    复制代码
     pg_dump -h ${DB_HOST} -p ${DB_PORT} -U ${DB_USER} -d ${DB_NAME} -Fc -f ${BACKUP_FILE}
     
     if [ $? -eq 0 ]; then
         echo "$(date) - ${DB_NAME} 备份成功" >> ${BACKUP_DIR}/backup.log
     else
         echo "$(date) - ${DB_NAME} 备份失败" >> ${BACKUP_DIR}/backup.log
     fi

    done

  2. 优化后脚本

    #!/bin/bash

    PostgreSQL多数据库自动备份脚本

    功能:备份指定数据库列表,压缩存储,自动清理7天前备份,记录详细日志

    数据库连接配置

    DB_HOST="localhost"
    DB_PORT="5432"
    DB_USER="postgres"
    export PGPASSWORD="your_password" # 建议使用.pgpass文件更安全

    备份配置

    BACKUP_DIR="/opt/postgresql_backups"
    DATE_STAMP=(date +"%Y%m%d_%H%M%S") RETENTION_DAYS=7 LOG_FILE="{BACKUP_DIR}/backup.log"

    要备份的数据库列表(排除系统数据库)

    DATABASES=("db1" "db2" "db3" "production_db")

    创建备份目录

    mkdir -p ${BACKUP_DIR}

    记录备份开始

    echo "(date +'%Y-%m-%d %H:%M:%S') - 开始PostgreSQL数据库备份" >> {LOG_FILE}

    循环备份每个数据库

    for DB_NAME in "{DATABASES[@]}"; do BACKUP_FILE="{BACKUP_DIR}/{DB_NAME}_backup_{DATE_STAMP}.dump"

    复制代码
     echo "$(date +'%Y-%m-%d %H:%M:%S') - 正在备份数据库: ${DB_NAME}" >> ${LOG_FILE}
     
     # 执行备份命令(使用自定义格式,支持压缩和选择性恢复)
     pg_dump -h ${DB_HOST} -p ${DB_PORT} -U ${DB_USER} -d ${DB_NAME} -Fc -v -f ${BACKUP_FILE} >> ${LOG_FILE} 2>&1
     
     # 检查备份是否成功
     if [ $? -eq 0 ]; then
         echo "$(date +'%Y-%m-%d %H:%M:%S') - 数据库 ${DB_NAME} 备份成功: ${BACKUP_FILE}" >> ${LOG_FILE}
         
         # 压缩备份文件
         gzip ${BACKUP_FILE}
         if [ $? -eq 0 ]; then
             echo "$(date +'%Y-%m-%d %H:%M:%S') - 备份文件已压缩: ${BACKUP_FILE}.gz" >> ${LOG_FILE}
         else
             echo "$(date +'%Y-%m-%d %H:%M:%S') - 警告: ${DB_NAME} 备份文件压缩失败" >> ${LOG_FILE}
         fi
     else
         echo "$(date +'%Y-%m-%d %H:%M:%S') - 错误: 数据库 ${DB_NAME} 备份失败!" >> ${LOG_FILE}
     fi

    done

    清理7天前的旧备份文件

    echo "(date +'%Y-%m-%d %H:%M:%S') - 开始清理超过{RETENTION_DAYS}天的旧备份" >> {LOG_FILE} find {BACKUP_DIR} -name "*.dump.gz" -type f -mtime +{RETENTION_DAYS} -exec rm -f {} \; if [ ? -eq 0 ]; then
    echo "(date +'%Y-%m-%d %H:%M:%S') - 成功清理超过{RETENTION_DAYS}天的旧备份文件" >> {LOG_FILE} else echo "(date +'%Y-%m-%d %H:%M:%S') - 警告: 清理旧备份文件时出错" >> ${LOG_FILE}
    fi

    echo "(date +'%Y-%m-%d %H:%M:%S') - 数据库备份流程完成" >> {LOG_FILE}

相关推荐
李广坤20 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Sinclair21 小时前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
Rockbean2 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
茶杯梦轩2 天前
CompletableFuture 在 项目实战 中 创建异步任务 的核心优势及使用场景
服务器·后端·面试
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
海天鹰3 天前
【免费】PHP主机=域名+解析+主机
服务器
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端