Windows版本PostgreSQL定时备份
备份脚本
backup.bat备份脚本内容如下
@echo off
setlocal enabledelayedexpansion:: 配置数据库连接参数
SET PGPASSWORD=******
SET DBUSR=postgres
SET DBHOST=localhost
SET DBPORT=5432
SET DBNAME=test:: 配置路径
SET PGPATH="D:\Server\PostgreSQL\16\bin\pg_dump.exe"
SET BACKUP_DIR="D:\Server\PostgreSQL\Backup":: 使用日期时间生成备份文件名(格式:数据库名_年月日_时分秒.backup)
set datetime=%date:~0,4%%date:~5,2%%date:~8,2%_%time:~0,2%%time:~3,2%%time:~6,2%
set datetime=%datetime: =0%
:: 处理小时为一位数时出现的空格
SET FILENAME=%DBNAME%_%datetime%.backup:: 创建备份目录(如果不存在)
if not exist %BACKUP_DIR% mkdir %BACKUP_DIR%:: 执行备份命令
echo 开始备份数据库 %DBNAME% ...
%PGPATH% -h %DBHOST% -p %DBPORT% -U %DBUSR% -F c -b -v -f "%BACKUP_DIR%\%FILENAME%" %DBNAME%:: 检查备份是否成功
if errorlevel 1 (echo [错误] 数据库备份失败!exit /b 1
) else (echo 数据库备份成功完成:%BACKUP_DIR%\%FILENAME%
):: 可选:清理旧备份(例如,只保留最近10天的备份)
:: forfiles /p "%BACKUP_DIR%" /m *.backup /d -10 /c "cmd /c del /q @path"
配置定时备份
命令输入taskschd.msc后打开配置定时任务页面