PostgreSQL定期备份的解决方法

前言

之前已经用pgagent实现了旧数据定期删除的方法

PostgreSQL需要定时清理旧数据的解决方法 - 掘金 (juejin.cn)

现在研究下如果实现定期备份

环境说明

我们需要第一在主机上创建一个文件夹用来存放保存好的文件(容器和本机都需要) 且本机的文件需要赋予权限

bash 复制代码
chmod o+W /你的文件地址

需要在容器中安装openssh-client、和sshpass

arduino 复制代码
apt install openssh-client
apt-get install sshpass

1、创建脚本

先查询下pg_dumpall工具位置:

arduino 复制代码
find / -name pg_dumpall

在容器的一个文件中创建sh脚本

bash 复制代码
cd /home
mkdir script
touch save.sh

脚本内容为(根据实际情况修改):

bash 复制代码
#!/bin/bash

# Description:备份 PostgreSQL 数据库并压缩成 gz 文件,最后删除 3 天前的备份文件。

echo "开始执行 PostgreSQL 数据库的备份..."
echo "backup ing..."
today=$(date +%Y-%m-%d)                       # 今天的日期
nowtime=$(date +%F+%T)                        # 当前时间点
yestoday=$(date -d '-3 day' +%Y-%m-%d)        # 3天前的日期
host_ip=127.0.0.1                             # 本机 IP 地址
backup_ip=你的远端地址                           # 远端备份服务器 IP
port_id=5432                                  # 端口号,PostgreSQL默认的端口号是5432    
username=postgres                             # 数据库用户             
export PGPASSWORD='你的密码'               # 数据库密码
dmpDir='你的目录'                          # 本地备份目录
destination='你的目录'                 # 远端备份目录

echo "时间:" $nowtime
set timeout 600

# /usr/bin/ 为 pg_dump 备份工具安装路径,根据实际情况更新此路径。

/usr/bin/pg_dumpall --file "$dmpDir/pg_backup_$today.sql" --host "$host_ip" --port "$port_id" --username "$username"
#--verbose --role "postgres" --format=c --blobs --encoding "UTF8" 备份转换扩展配置

echo "PostgreSQL 数据库备份完成!"

echo "当天备份文件压缩中..."
gzip "$dmpDir/pg_backup_$today.sql"
echo "3 天前的 PostgreSQL 数据库备份文件已删除!"

echo "开始远端备份..."
export SSHPASS=your_password
sshpass -e scp -r "$dmpDir/pg_backup_$today.sql.gz" (你的登录名)@$backup_ip:$destination

echo "远端备份完毕,感谢您使用此脚本!"
exit;

给脚本增加可执行权限

bash 复制代码
chmod +x save.sh

2、用pgAgent设置定时任务

点击创建 输入名称 点击步骤创建 点击编辑------添加运行代码

创建计划任务: 最后在重复中:添加每日执行时间 最后记得保存!

结语

我们借用pgAgent完成了数据库的日常2个定时任务,清理数据、保存数据库。

本次参考文章为:

太强了!MySQL、Oracle、PostgreSQL 数据库备份拿来就用的 Shell 脚本! - 掘金 (juejin.cn)

相关推荐
last_zhiyin2 小时前
Oracle sql tuning guide 翻译 Part 6-4 --- Hint使用准则和Hint使用报告
数据库·sql·oracle·sql tunning
java_logo3 小时前
Docker 部署 WordPress 全流程
运维·docker·容器·word·php·1024程序员节
摇滚侠4 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
auspicious航6 小时前
PostgreSQL数据库关于pg_rewind的认识
数据库·postgresql·oracle
武子康6 小时前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节
摇滚侠7 小时前
全面掌握PostgreSQL关系型数据库,设置远程连接,笔记05,笔记06
java·数据库·笔记·postgresql
mpHH7 小时前
postgresql plancache --doing
数据库·学习·postgresql·1024程序员节
wodongx1237 小时前
从一开始部署Android项目Sonarqube的自动化扫码+通知+增量扫描功能(Win环境、Docker,基于Jenkins)
运维·docker·jenkins·1024程序员节
java_logo8 小时前
Docker 部署 Elasticsearch 全流程手册
大数据·运维·mongodb·elasticsearch·docker·容器
235169 小时前
【MySQL】慢查寻的发现和解决优化(思维导图版)
java·后端·sql·mysql·职场和发展·数据库开发·数据库架构