微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当python脚本作为systemd服务运行时,Python Popen不识别scrapy

我有一个需要启动scrapy可执行文件的python脚本main.py,所以我使用Popen来做(使用subprocess.call()有相同的结果).为了简化事情我只是运行scrapy的帮助论点.

import subprocess
...
p = subprocess.Popen(['scrapy', '-h'])

该脚本需要在安装了scrapy的vitualenv内运行.当我激活virtualenv并将脚本作为python main.py运行时,命令scrapy -h按预期执行.

现在,我需要将此脚本作为systemd服务运行.我已经为脚本创建了systemd单元,如下所示:

[Unit]
Description=Scrapy test
After=network.target

[Service]
User={{ scrapy_user }}
WorkingDirectory={{ test_path }}
ExecStart={{ virtualenv_path }}/bin/python {{ test_path }}/main.py

[Install]
WantedBy=multi-user.target

当我使用sudo systemctl start scrapy-test启用和启动服务时,代码会正常运行,直到p = subprocess.Popen([‘scrapy’,’ – h’])当我收到异常时

File "{{ test_path }}/main.py", line 52, in launch_spider
   p = subprocess.Popen(['scrapy', '-h'])
File "/usr/lib/python2.7/subprocess.py", line 710, in __init__
   errread, errwrite)
File "/usr/lib/python2.7/subprocess.py", line 1335, in _execute_child
   raise child_exception
OSError: [Errno 2] No such file or directory

我还尝试通过在Popen之前添加os.chdir(‘{{virtualenv_path}} / bin’)来更改工作目录,但是我得到完全相同的异常.我确信该脚本是通过virtualenv运行的,因为(1)它是在ExecStart属性中设置的,(2)在导入未安装在系统python中的模块时,脚本会引发异常.

解决方法:

线索在这里

ExecStart={{ virtualenv_path }}/bin/python {{ test_path }}/main.py

scrapy命令位于$VIRTUAL_ENV / bin上,该命令不在systemd $PATH上.

你可以尝试:

import os
import subprocess
p = subprocess.Popen(['%s/bin/scrapy' % os.environ['VIRTUAL_ENV'], '-h'])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐