我一直试图用nginx将我的烧瓶代码移动到uwsgi中。它经历了502(错误的套接字文件名)到404(默认应用0 - 没有在nginx配置中加载可运行的代码),到现在为500,我没有关于原因的信息。
慢慢但肯定地,修改似乎来自我的uwsgi.ini或nginx.sites文件中的问题,而我真的只是希望有人审核它们并解释发生了什么。
uwsgi.ini:
# can't these take over from nginx?
[uwsgi]
base = /home/aristatek/britishQueue
home = /home/aristatek/britishQueue
venv = /home/aristatek/britishQueue/clearable
socket = /home/aristatek/britishQueue/uwsgi.sock
chmod-socket = 666
wsgi-file = uwsgi.py
callable = application
daemonize=/home/aristatek/britishQueue/uwsgi.log
master = true
processes = 4
threads = 2
nginx config:
server {
server_name intern.alpha.aristatek.com default_server;
listen 80;
location / {
root /home/aristatek/britishQueue/srv/;
}
location /api/ { try_files $uri @britishQueue; }
location @britishQueue {
include uwsgi_params;
uwsgi_param UWSGI_BASE /home/aristatek/britishQueue;
uwsgi_param UWSGI_HOME /home/aristatek/britishQueue;
uwsgi_param UWSGI_VENV /home/aristatek/britishQueue/clearable;
uwsgi_param UWSGI_MODULE uwsgi;
uwsgi_param UWSGI_CALLABLE application;
uwsgi_pass unix:/home/aristatek/britishQueue/uwsgi.sock;
}
}
uwsgi.py:
#!/usr/bin/env python
from britishQueue import webserve as application # why so picky all the time..
if __name__ == "__main__":
application.run(host='0.0.0.0', port=6002, debug=True)
哪一个应该能够正确帮助我在uwsgi的控制下启动服务器?
我已经创建了一个git分支,如果需要,只有更相关的代码(并且总是有主分支):https://github.com/Thetoxicarcade/britishQueue/tree/flaskBug
编辑(使用生产的日志文件):
*** Starting uWSGI 2.0.12 (64bit) on [Tue Jan 19 14:40:02 2016] ***
compiled with version: 4.8.4 on 13 January 2016 14:22:40
os: Linux-3.16.0-57-generic #77~14.04.1-Ubuntu SMP Thu Dec 17 23:20:00 UTC 2015
nodename: intern.alpha.aristatek.com
machine: x86_64
clock source: unix
pcre jit disabled
detected number of CPU cores: 8
current working directory: /home/aristatek/britishQueue/flask
detected binary path: /usr/local/bin/uwsgi
your processes number limit is 31835
your memory page size is 4096 bytes
detected max file descriptor number: 1024
lock engine: pthread robust mutexes
thunder lock: disabled (you can enable it with --thunder-lock)
uwsgi socket 0 bound to UNIX address /home/aristatek/britishQueue/flask/uwsgi.sock fd 3
Python version: 2.7.6 (default, Jun 22 2015, 18:01:27) [GCC 4.8.2]
Set PythonHome to /home/aristatek/britishQueue/clearable
Python main interpreter initialized at 0x1ab2c80
python threads support enabled
your server socket listen backlog is limited to 100 connections
your mercy for graceful operations on workers is 60 seconds
mapped 415360 bytes (405 KB) for 8 cores
*** Operational MODE: preforking+threaded ***
WSGI app 0 (mountpoint='') ready in 1 seconds on interpreter 0x1ab2c80 pid: 1148 (default app)
spawned uWSGI master process (pid: 1148)
spawned uWSGI worker 1 (pid: 1280, cores: 2)
spawned uWSGI worker 2 (pid: 1281, cores: 2)
spawned uWSGI worker 3 (pid: 1283, cores: 2)
spawned uWSGI worker 4 (pid: 1286, cores: 2)
[pid: 1286|app: 0|req: 1/1] 192.168.2.60 () {54 vars in 1147 bytes} [Tue Jan 19 14:40:14 2016] GET /api/v1.0/status/ => generated 291 bytes in 30 msecs (HTTP/1.1 500) 2 headers in 84 bytes (1 switches on core 0)
[pid: 1286|app: 0|req: 2/2] 192.168.2.60 () {54 vars in 1147 bytes} [Tue Jan 19 14:40:15 2016] GET /api/v1.0/status/ => generated 291 bytes in 1 msecs (HTTP/1.1 500) 2 headers in 84 bytes (1 switches on core 1)
[pid: 1286|app: 0|req: 3/3] 192.168.2.60 () {54 vars in 1147 bytes} [Tue Jan 19 14:40:15 2016] GET /api/v1.0/status/ => generated 291 bytes in 1 msecs (HTTP/1.1 500) 2 headers in 84 bytes (1 switches on core 0)
答案 0 :(得分:1)
让我们把它分成几步。
首先,你的应用程序似乎有一些内置的http服务器,让我们运行它。只需致电python wsgi.py
,地址127.0.0.1:6002
将成为您的应用程序(如果您在远程服务器上执行此操作,请将127.0.0.1替换为其IP地址)。
这有助于缩小应用程序中的错误。
如果这样可以正常工作,请停止该应用程序服务器(可能是ctrl + c或ctrl + d)。
现在,当您确定应用程序正在运行时,让我们尝试将其置于uWSGI之后。这是每次都适合我的配置:
chdir = /home/aristatek/britishQueue # put here directory, where you're storing your app code
uid = aristatek # username and groupname on which your app will be running (if you're running uWSGI as root, you really should do this, for security reasons)
gid = aristatek
auto-procname = 1 # this 2 options will set user-readable name for your uWSGI processes, in this example each processname will be prefixed by your username and app name
procname-prefix-spaced = [aristatek_britishQueue]
#chmod-socket = 660 # this 2 options will ensure that your socket will be readable by user that is running app and uWSGI, no one else.
#chown-socket = aristatek:www-data
#socket = /home/aristatek/britishQueue/uwsgi.sock
http = :8000
pidfile2 = /home/aristatek/britishQueue/uwsgi.pid
virtualenv = /home/aristatek/britishQueue/clearable
workers = 4
threads = 2
master = true
module = wsgi # python path to your wsgi file, relative to main project dir
enable-threads = 1
logger = file:/home/aristatek/britishQueue/uWSGI.log
运行该uWSGI服务器后,转到浏览器中的127.0.0.1:8000
。这应该与运行应用程序内置服务器的结果相同。如果没有,请检查uWSGI日志(默认情况下位于项目目录中),以找出它无法正常工作的原因。
如果uWSGI工作正常,请在其配置行中取消注释socket
并注释http one
(或删除)。
这是我的nginx与uWSGI应用程序通信的配置:
server {
listen 80;
server_name intern.alpha.aristatek.com default_server;
client_max_body_size 4G;
root /home/aristatek/britishQueue/srv/;
location @britishQueue {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
include /etc/nginx/uwsgi_params;
uwsgi_pass unix:/home/aristatek/britishQueue/uwsgi.sock;
break;
}
location /api/ {
try_files $uri @default;
}
error_page 500 502 503 504 /500.html;
location = /500.html {
try_files /500.html /error.html /error500.html;
}
}
就是这样,您的应用应该可以通过地址intern.alpha.aristatek.com
访问。如果不是,请检查nginx错误以及nginx是否在www-data
用户和组上运行,如果没有,请在uWSGI配置文件中更改uwsgi套接字的groupname。
答案 1 :(得分:1)
需要直接告诉Uwsgi使用类似异步的方法。就我而言,那是:
[uwsgi]
plugins = python
virtualenv = /home/aristatek/britishQueue/clearable
chdir = /home/aristatek/britishQueue/flask
module = britishQueue
callable = webserve
uid = aristatek
gid = aristatek
#http = :6002
socket = /home/aristatek/britishQueue/flask/uwsgi.sock
chown-socket = www-data:www-data
chmod-socket = 666
pidfile2 = /home/aristatek/britishQueue/flask/uwsgi.pid
stats = /home/aristatek/britishQueue/flask/uwsgi.stats
#master = true
ugreen = true
async = 4
#workers = 4
#enable-threads = 1
#threads = 4
#auto-procname = 1
#procname-prefix-spaced = [aristatek_britishQueue]
哪个非常有效,让失败的线程自行失败:)