我正在使用 Ubuntu 16.04 xenial。在 ubuntu 机器上我安装了 BigsqlPostgres 版本 10。它安装在如下目录中:
BigsqlPostgres:
/etc/bigsql/pg10/bin/
/etc/bigsql/data/
我正在使用以下脚本来备份数据库:
import os, boto3, pytz, sys
parent_dir = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
sys.path.append(parent_dir)
from sellerhub_midport.utils.variables import _POSTGRES_HOST, _POSTGRES_PORT, _POSTGRES_USERNAME, _POSTGRES_PASSWORD, _POSTGRES_DBNAME, _AWS_ACCESS_KEY_ID, _AWS_SECRET_KEY, _BUCKET_NAME
from datetime import datetime
class BackupDatabase(object):
"""docstring for BackupDatabase"""
def __init__(self):
super(BackupDatabase, self).__init__()
localtz = pytz.timezone('UTC')
self.filename = 'report'+datetime.now(localtz).strftime('%Y_%m_%d') + '.dump'
self.pathname = 'prod_backup/' + self.filename
self.backup_database()
def backup_database(self):
os.putenv('PGPASSWORD', _POSTGRES_PASSWORD)
os.system('/etc/bigsql/pg10/bin/pg_dump --format=c -h {} -p 5432 -d {} -U {} > {}'.format(_POSTGRES_HOST, _POSTGRES_DBNAME, _POSTGRES_USERNAME, self.filename))
boto3_res = boto3.resource(service_name='s3', aws_access_key_id=_AWS_ACCESS_KEY_ID, aws_secret_access_key=_AWS_SECRET_KEY,)
with open(self.filename, 'rb') as f_obj:
boto3_res.Bucket(_BUCKET_NAME).put_object(Key=self.pathname, Body=f_obj)
os.remove(self.filename)
BackupDatabase()
如果我在我的 django 虚拟环境中运行 backup.py 文件,它会创建一个以当前时间戳命名的备份文件。但是当我为此编写一个 cron 作业时它不起作用,我的意思是不创建数据库的备份,但是当我运行时这个文件手动工作正常。下面是我为备份数据库而编写的 cron。
10 14 * * * /usr/bin/python /home/ekodev/sellerhub_midport/sellerhub_midport/scripts/service_crons/backup_db.py > /tmp/listener.log 2>&1
我没有收到任何日志错误。如果我查看/tmp/listener.log
它向我展示的系统就可以了。
感谢您的宝贵时间。