在让主管运行我的龙卷风应用程序时遇到了一些问题。
我有一个使用 Flask 构建的 REST API,并使用 Tornado 尝试为其提供服务。我遇到的问题是,当我尝试使用 Supervisor 运行时,导入其他支持 Python 包似乎失败了。
inf_api 是 flask API。
这是龙卷风的脚本
from influence_api import app
from tornado.wsgi import WSGIContainer
from tornado.httpserver import HTTPServer
from tornado.ioloop import IOLoop
from tornado.options import define, options
define("port", default=8080, help="Port to listen on", type=int)
if __name__ == '__main__':
options.parse_command_line()
http_server = HTTPServer(WSGIContainer(app))
http_server.listen(options.port)
IOLoop.instance().start()
Supervisord.conf 的程序部分(我已尝试过多次迭代)
[program:tornado-8080]
autostart=true
autorestart=true
environment=USER=root,PYTHONPATH=/usr/bin/
command=python /media/sf_Projects/inf_api/inf_api/inf_server_nginx.py
stderr_logfile = /var/log/supervisord/tornado-stderr.log
stdout_logfile = /var/log/supervisord/tornado-stdout.log
我尝试过在环境中放入多少以及在命令中直接放入多少。包括以下变化......
user=root
autostart=true
autorestart=true
exitcodes=0,1,2
command=env PATH="/usr/bin/python" /media/sf_Projects/inf_api/inf_api/inf_server_nginx.py --port=8081
command=/usr/bin/python /media/sf_Projects/inf_api/inf_api/inf_nginx.py --port=8081
stderr_logfile = /var/log/supervisord/tornado-stderr.log
stdout_logfile = /var/log/supervisord/tornado-stdout.log
主管的错误输出
2014-02-25 16:55:24,917 INFO spawned: 'tornado-8080' with pid 3527
2014-02-25 16:55:25,156 DEBG 'tornado-8080' stderr output:
Traceback (most recent call last):
File "/media/sf_Projects/inf_api/inf_api/inf_server_nginx.py", line 11, in <module>
2014-02-25 16:55:25,157 DEBG 'tornado-8080' stderr output:
from inf_api import app
2014-02-25 16:55:25,157 DEBG 'tornado-8080' stderr output:
File "/media/sf_Projects/inf_api/inf_api/inf_api.py", line 159, in <module>
2014-02-25 16:55:25,158 DEBG 'tornado-8080' stderr output:
mongo_ip = read_config('Database')['mongoip']
2014-02-25 16:55:25,158 DEBG 'tornado-8080' stderr output:
File "/media/sf_Projects/inf_api/inf_api/inf_api.py", line 114, in read_config
2014-02-25 16:55:25,158 DEBG 'tornado-8080' stderr output:
options = config.options(section)
2014-02-25 16:55:25,159 DEBG 'tornado-8080' stderr output:
File "/usr/lib/python2.7/ConfigParser.py", line 279, in options
raise NoSectionError(section)
ConfigParser.NoSectionError: No section: 'Database'
.........
2014-02-25 20:29:26,924 INFO exited: tornado-8080 (exit status 1; not expected)
运行 Tornado 时,无论是否使用 SSL 都可以正常工作,Flask API 独立运行也是如此。使用 sudo 和不使用 sudo 运行了 Supervisord……
正如您所看到的,我很困惑 – 有什么想法吗?
答案1
我想我已经解决了:确保我使用的目录中的所有 python 文件都是可执行的
chmod +x <FILES>
修改了supervisord文件的程序部分,如下所示
[program:inf_svr]
process_name=inf_svr%(process_num)s
directory=/media/sf_Projects/inf_api/inf_api/
environment=USER=root,PYTHONPATH=/usr/bin/
command=python /media/sf_Projects/inf_api/inf_api/inf_server_nginx.py
startsecs=2
user=root
autostart=true
autorestart=true
numprocs=1
numprocs_start=8080
stderr_logfile = /var/log/supervisord/tornado-stderr.log
stdout_logfile = /var/log/supervisord/tornado-stdout.log