Centos7 上使用Crontab执行Python脚本

  • 背景
  • 问题查找
  • 查看日志
  • 问题解决


背景

Centos7采用最小化安装。使用Django时有一个计划任务的执行需求,本来想手动创建crontab任务,创建之后crontab正常执行,但是python脚本却没有执行

问题查找

我向来比较懒,有问题直接搜,于是乎,找了CSDN上几个方法尝试了几次,发现不起作用,有的说是自己创建一个shell脚本,在shell脚本中去执行python脚本,有的说是环境变量问题(这个问题最好解决,所有路径使用绝对路径即可),还有的说执行目录的问题(这个跟环境变量其实一个问题,还是绝对路径)。我尝试了几个方法之后都不生效,我开始有点慌了。

查看日志

网上的方法都不奏效,没办法,只能自己来了,查看crontab日志,执行正常

/var/log/cron

crontab 调用python脚本 crontab执行python脚本无效_库文件


查看用户的mail信箱,发现是空的。这就不应该了,crontab执行如果出错了会给执行用户发一封mail邮件,可以用mail命令查看,但是这里是空的,就不太正常了,crontab默认日志是发邮件的,但是我的mail里面是空的,所以查看一下postfix邮件代理,发现postfix根本就启动不起来

crontab 调用python脚本 crontab执行python脚本无效_库文件_02


既然报错/use/sbin/postconf不能执行,那就手动执行试试看,但是手动执行报错libmysqlclient_18没定义,在此经过一番搜索找到问题点是,由于系统最小化安装没有数据库,源码安装了mysql8,mysql8的是libmysqlclient.so.20,libmysqlclient_18是mysql5的库文件,于是安装mysql-commmunity-libs-compat-5.7*版本的rpm包即可,之后mail就工作正常了。

再次查看root的mail信箱,全是邮件,打开一个邮件查看错误信息

crontab 调用python脚本 crontab执行python脚本无效_库文件_03

问题解决

这里python报错找不到libpython3.9.so.1.0这个库文件,这个报错正常,我的python也是源码安装,没有把python安装目录的库文件链接到/usr/lib或者/usr/lib64。按照大神的步骤,在/etc/ld.so.conf.d/目录下新建python3.conf文件,把/usr/local/python3.9/lib路径写进刚才新建的文件中,然后ldconfig刷新。重新查看crontab计划任务执行情况,发现已经正常了