加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何检查postgresql备份是否成功?

发布时间:2020-12-13 18:04:26 所属栏目:百科 来源:网络整理
导读:我们有一个 postgresql数据库,每晚从一个cron作业备份,并带有以下命令: su postgres -c "pg_dump our_database | gzip /home/smb/shared/database_backup.bak.gz" 最近我们有一个磁盘故障,从一些坏扇区开始,在此期间pg_dump退出时出现以下错误 pg_dump: SQL
我们有一个 postgresql数据库,每晚从一个cron作业备份,并带有以下命令:
su postgres -c "pg_dump our_database | gzip > /home/smb/shared/database_backup.bak.gz"

最近我们有一个磁盘故障,从一些坏扇区开始,在此期间pg_dump退出时出现以下错误

pg_dump: SQL command failed
pg_dump: Error message from server: ERROR: catalog is missing 17 attribute(s) from relid 20158
pd_dump: The command was: LOCK TABLE public.obvez IN ACCESS SHARE MODE

现在,因为它是在cron作业,没有人注意到错误消息,备份被中断,但它不是零大小,一切似乎都没有,并且当我们意识到我们没有备份时,错误被忽视直到最终磁盘失败.

我们设法从较旧的备份恢复数据,但现在我想知道检查pg_dump是否成功完成其工作的正确方法是什么?

我将结果写入日志文件,在cronjob的末尾,我将日志文件的内容发送到我的电子邮件地址.那样的话,我会知道什么时候出错了.
su postgres "pg_dump our_database 2>> $LOG_FILE | gzip > /home/smb/shared/database_backup.bak.gz"
cat $LOG_FILE | mailx $MAINTAINERS -s "Postgresql backup"

ADDENDUM:如果您只想在出现任何问题时发送电子邮件,可以查看pg_dump的返回码:

LOG_FILE=/tmp/pgdump.err

if ! pg_dump -U backupuser "our_database" 2> $LOG_FILE 
then 
    cat $LOG_FILE | mailx 'youremailaddress' -s "Postgresql backup failure!"
fi

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读