项目需求是要求一个月前的云主机快照都要删除,想着写个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里面,以上