17

我可以在脚本中运行诸如 vacuumdb、pg_dump 和 psql 之类的命令,如果我像这样为它们添加前缀:

/usr/bin/sudo -u postgres /usr/bin/pg_dump -Fc mydatabase > /opt/postgresql/prevac.gz
/usr/bin/sudo -u postgres /usr/bin/vacuumdb --analyze mydatabase
/usr/bin/sudo -u postgres /usr/bin/pg_dump -Fc mydatabase > /opt/postgresql/postvac.gz
SCHEMA_BACKUP="/opt/postgresql/$(date +%w).db.schema"
sudo -u postgres /usr/bin/pg_dump -C -s mydatabase > $SCHEMA_BACKUP

当我 sudo 到 root 时,这些在 Redhat 的命令行上运行,然后如您在上面的命令中看到的,我对 postgres 执行 sudo -u。

但是当我尝试从 cron 启动它时,我在所有文件中得到零字节——这意味着它没有正常运行。而且我在我可以看到的日志中没有任何线索。

我的 /etc/crontab 文件底部有这个条目

00 23 * * * root /etc/db_backup.cron

是的,/etc/db_backup.cron 是 chmod ug+x,由 root 拥有,文件顶部显示“#!/bin/bash”(减去双引号)。

有谁知道给了什么?

4

8 回答 8

17

由于您似乎拥有超级用户权限,您可以将这些命令放入 postgres 用户的 crontab 中,如下所示:

sudo su postgres
crontab -e

然后将 pg_dump/vacuumdb 命令放在那里。

于 2009-05-12T18:48:35.787 回答
14

我有一个备份服务器上所有数据库的动态 bash 脚本。它获取所有数据库的列表,然后在执行备份之前清空每个数据库。所有日志都写入一个文件,然后将该日志通过电子邮件发送给我。如果你愿意,这是你可以使用的东西。

将下面的代码复制到一个文件中,并将该文件添加到您的 crontab 中。我已将 pg_hba.conf 设置为信任本地连接。

#!/bin/bash
logfile="/backup/pgsql.log"
backup_dir="/backup"
touch $logfile
databases=`psql -h localhost -U postgres -q -c "\l" | sed -n 4,/\eof/p | grep -v rows\) | grep -v template0 | grep -v template1 | awk {'print $1'}`

echo "Starting backup of databases " >> $logfile
for i in $databases; do
        dateinfo=`date '+%Y-%m-%d %H:%M:%S'`
        timeslot=`date '+%Y%m%d%H%M'`
        /usr/bin/vacuumdb -z -h localhost -U postgres $i >/dev/null 2>&1
        /usr/bin/pg_dump -U postgres -i -F c -b $i -h 127.0.0.1 -f $backup_dir/$i-database-$timeslot.backup
        echo "Backup and Vacuum complete on $dateinfo for database: $i " >> $logfile
done
echo "Done backup of databases " >> $logfile

tail -15 /backup/pgsql.log | mailx youremail@domain.com
于 2009-06-05T21:20:20.153 回答
7

我已经像这样设置了我的 cron。从周一到周五每 59 分钟一班

*/59 * * * 1-5 sh /home/my_user/scripts/back_my_bd.sh 

运行备份的脚本位于back_my_bd.sh文件中,内容为:

pg_dump -U USERDATABASE DATABASENAME > /home/my_user/sql/mybackup.sql

我在主目录中创建了 .pgpass 文件,以允许在不指定用户和密码的情况下进行备份

localhost:5432:DATABASENAME:USER:PASSWORD

对不起,我的英语不好!

于 2016-02-02T19:01:05.630 回答
4

您的环境变量可能未在 cron 中设置。

在您的正常会话中,您可能已经定义了以下变量:

PG_PORT
PG_HOST
PG_DATABASE
PG_USERNAME
PG_PASSWORD

在你的脚本中添加一个“env”。

于 2009-05-12T18:47:45.087 回答
1

您的 pg_hba.conf 中可能为您的 postgres 用户提供了“ident”身份验证。在这种情况下,选项“-u postgres”会失败。在备份脚本中将用户更改为 postgres 或配置不同的身份验证方法。

于 2011-06-19T11:30:15.937 回答
0

获取数据库列表的另一个版本:
psql -lqt | grep -vE '^ +(template[0-9]+|postgres)? *\|' | cut -d'|' -f1| sed -e 's/ //g' -e '/^$/d'

因为我的psql -lqt输出是:

 abcdefghij         | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 postgres           | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 template1          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 abc                | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
于 2013-04-04T21:08:53.333 回答
0

数据库=psql -h localhost -U postgres -q -x -t -c "\l" | grep 'Name' | sed 's/ //g' | sed 's/Name|//g'

于 2013-03-15T06:26:00.463 回答
0

而不是以下命令:databases=psql -h localhost -U postgres -q -c "\l" | sed -n 4,/\eof/p | grep -v rows\) | grep -v template0 | grep -v template1 | awk {'print $1'}

您可以在下面使用:数据库=psql -t -c "select datname from pg_database where datname not like 'template%';" | grep -v '^$'

第一个返回'|' 对于模板数据库和一个空行。

第二个更干净。

于 2013-02-20T13:14:05.927 回答