我有一个用nginx服务的uWSGI下的python烧瓶应用程序。python代码调用subprocess.Popen()来运行浏览器(即Firefox、Chrome),但是uWSGI日志显示了错误。该错误与linux(ubuntu)标准命令(即readlink、which、cat等)有关。
我怀疑这是与用户访问有关的,但不确定。uWSGI服务使用我的用户和www-data组运行。
Python代码
import subprocess
@app.route('/api/check/version', methods=['POST'])
def check_version():
pid = subprocess.Popen(['/usr/bin/firefox', '--version'], stdout=subprocess.PIPE)
#pid = subprocess.Popen(['/usr/bin/google-chrome', '--version'], stdout=subprocess.PIPE)
data = pid.communicate()
return data
if __name__ == "__main__":
check_version()uWSGI log
**in case of doing Popen for /usr/bin/firefox
/usr/bin/firefox: 1: /usr/bin/firefox: which: not found
**in case of doing Popen for /usr/bin/google-chrome
/usr/bin/google-chrome-stable: line 8: readlink: command not found
/usr/bin/google-chrome-stable: line 10: dirname: command not found
/usr/bin/google-chrome-stable: line 46: exec: cat: not found
/usr/bin/google-chrome-stable: line 45: exec: cat: not founduWSGI Service Config
[Unit]
Description=uWSGI instance to serve myproject
After=network.target
[Service]
User=myuser
Group=www-data
WorkingDirectory=/home/gbadmin/myproject
Environment="PATH=/home/gbadmin/myproject/myprojectenv/bin"
ExecStart=/home/gbadmin/myproject/myprojectenv/bin/uwsgi --ini myproject.ini
[Install]
WantedBy=multi-user.target发布于 2017-08-27 19:15:38
你给了你的PATH一个限制太大的价值:
Environment="PATH=/home/gbadmin/myproject/myprojectenv/bin"问题中缺少的命令通常出现在/bin或/usr/bin中,将这些命令添加到path变量中可能解决问题。
Environment="PATH=/home/gbadmin/myproject/myprojectenv/bin:/usr/bin:/bin"发布于 2017-08-27 16:38:21
我没有回答你的问题,但我想我正在解决你遇到的问题。作为另一种选择,您可以使用dpkg -s firefox | grep '^Version:'而不是您正在使用的方法。
https://stackoverflow.com/questions/45906997
复制相似问题