Centos7 上使用Crontab执行Python脚本不生效

Centos7 上使用Crontab执行Python脚本

背景

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

问题查找

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

查看日志

网上的方法都不奏效,没办法,只能自己来了,查看crontab日志,执行正常
/var/log/cron
crontab执行日志
查看用户的mail信箱,发现是空的。这就不应该了,crontab执行如果出错了会给执行用户发一封mail邮件,可以用mail命令查看,但是这里是空的,就不太正常了,crontab默认日志是发邮件的,但是我的mail里面是空的,所以查看一下postfix邮件代理,发现postfix根本就启动不起来

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

问题解决

这里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计划任务执行情况,发现已经正常了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值