crontab 定时执行django自定义命令的坑

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013205877/article/details/83420433

项目需求是要求一个月前的云主机快照都要删除,想着写个Django自定义命令,扔到crontab里面跑,跑来跑去测试和我说没删掉,怎么会?一开始怀疑crontab,但是试试其他任务都跑了啊,然后django自定义命令里面加日志也没见到有日志输出,最后我成哥提醒,加crontab日志,终于发现症结所在了。。。
日志显示jango.db.utils.OperationalError: (2003, ‘Can’t connect to MySQL server on ‘127.0.0.1’ (111 “Connection refused”)’),WTF,没读到环境变量连不上数据库啊,Google 上各路方法souce一堆都不管用,最后只能改为定时执行shell脚本,脚本中写自定义命令了。。。
1.shell脚本

#!/bin/bash
###################
. /etc/profile
. ~/.bash_profile
##################
source /.venv/bin/activate
.venv/bin/python manage.py 自定义命令

2./etc/crontab

10 20 * * * root sh /var/www/ecscloud_web/delete_vm_snapshot.sh

3.自定义命令开头加上

#!.venv/bin/python

终于搞定了,快照删掉了,坑爹的问题啊,crontab遇到环境变量问题,能用shell脚本的就不要直接写/etc/crontab里面,以上

猜你喜欢

转载自blog.csdn.net/u013205877/article/details/83420433