运行在亚马逊EC2上的Ubuntu机器18.04。我有一个python脚本,它轮询API并将结果写入同一目录中的一个json文件。我设置了一个cron作业,每5分钟运行一次。问题是作业正在运行,我在日志中看到了它,但文件并未写入。当我手动运行该脚本时,json文件会按预期编写。
文件夹和.py文件权限为775。
下面是crontab条目(我从sudo crontab -e
访问它):
*/5 * * * * ubuntu python3 /home/ununtu/var/www/html/api.py >
/home/ubuntu/var/www/html/cron.log 2>&1
cron.log文件显示了python脚本的预期输出。/var/log/syslog
显示:
(root) CMD (ubuntu python3 /home/ununtu/var/www/html/api.py >
/home/ubuntu/var/www/html/cron.log 2>&1)
每隔五分钟。
请帮我弄清楚这一点。
发布于 2019-05-23 20:26:56
我也有同样的问题,但我无法解决它……
在我的例子中,我使用python库(BlockingScheduler)来解决它,并使用tmux在后台进程中执行它。
一个简单的用法示例:
from apscheduler.schedulers.blocking import BlockingScheduler
def test():
test_write = 'hello'
with open('logs.txt', 'a') as f:
f.write('test: {}\n'.format(test_write))
scheduler = BlockingScheduler()
scheduler.add_job(test, 'interval', seconds=5)
scheduler.start()
希望它能帮上忙!
https://stackoverflow.com/questions/56275039
复制相似问题