9

我的服务器上运行了一个 python 应用程序(具体的 Django)。昨天之前用mod-wsgi在apache下成功运行,几乎没有问题。我有两个主要原因切换到 nginx:

  • 性能 - 在 nginx 下,我几乎有一半的时间来处理每个请求
  • 两个应用程序一起在 apache 下没有成功运行 - 由 nginx 解决
  • 第三个原因是对我来说更好的配置

我的 uwsgi 服务有问题。首先,我将包含应用程序的 wsgi 文件:

import os
import sys 

path = os.path.abspath(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

if path not in sys.path:
sys.path.append(path)

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "usporion.settings")

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

然后我有 init 应用程序的 uwsgi.ini 文件,位于/etc/uwsgi/apps-enabled/usporion.ini

[uwsgi]
plugins = python
uid = www-data
gid = www-data
uwsgi-socket = /srv/sockets/usporion.sock
chmod-socket = 664
chdir = /srv/www/usporion
pythonpath = /srv/www/usporion
module = usporion.wsgi
env = DJANGO_SETTINGS_MODULE=usporion.settings
logdate = True
logto = /var/log/uwsgi/usporion.log
#daemonize = /var/log/uwsgi/usporion.log
vacuum = True
max-requests = 1000
processes = 5
threads = 10
workers = 5
vhost = True

注意:我试图取消注释的守护进程(但这不适用于当前使用情况)。

最后,我有这个 nginx 配置:

upstream django {
    server 95.168.193.219:80;
}

server {
    listen          95.168.193.219:80;
    server_name     usporion.cz;
    return      301 $scheme://www.usporion.cz$request_uri;
}

server {
    listen          95.168.193.219:80;
    server_name     www.usporion.cz;
    charset         utf-8;

    client_max_body_size 100M;

    location /media {
        alias       /srv/www/usporion/media;
        expires     1d;
    }

    location /static {
        alias       /srv/www/usporion/static;
        expires     1d;
    }

    location / {
        root        /srv/www/usporion;
        include     uwsgi_params;
        uwsgi_pass  unix:///srv/sockets/usporion.sock;
    }
}

运行命令uwsgi --ini /etc/uwsgi/apps-enabled/usporion.ini运行良好,我可以看到应用程序在网络上运行。但是,如果我这样做service uwsgi start,服务不会启动(失败),没有消息,我在日志中找不到任何内容。在未启用应用程序的情况下运行此服务usporion.ini工作正常。

我会很高兴有任何帮助,因为我可以避免在屏幕下运行 uwsgi“服务”但作为正常服务运行。

这是分布信息:

root@[name]:/etc/nginx/sites-enabled# uname -a
Linux [name] 2.6.32-5-amd64 #1 SMP Sun Sep 23 10:07:46 UTC 2012 x86_64 GNU/Linux
root@[name]:/etc/nginx/sites-enabled# cat /etc/debian_version 
6.0.7
root@[name]:/etc/nginx/sites-enabled# nginx -v
nginx version: nginx/1.2.6
root@[name]:/etc/nginx/sites-enabled# uwsgi --version
1.2.3-debian
root@[name]:/etc/nginx/sites-enabled# python --version
Python 2.7.3

最后,如果有人想给我一些配置建议(我是 nginx 新手,很受欢迎),这是 8 核 Xeon 服务器 2.4GHz 和 16GB RAM,其中一半是为这个应用程序保留的。

4

1 回答 1

3

错误是uwsgi配置:

[uwsgi]
plugins = python
uid = www-data
gid = www-data
uwsgi-socket = /srv/sockets/usporion.sock
chmod-socket = 664
chdir = /srv/www/usporion
pythonpath = /srv/www/usporion
wsgi-file = /srv/www/usporion/usporion/wsgi.py
env = DJANGO_SETTINGS_MODULE=usporion.settings
logdate = True
logto = /var/log/uwsgi/usporion.log
#daemonize = /var/log/uwsgi/usporion.log
vacuum = True
max-requests = 1000
master = True
enable-threads = True
processes = 5
threads = 10
vhost = True

不同之处在于wsgi-file,替换了旧module配置值的内容。然后,出现了关于缺少 wsgi 文件的错误(第一次写入错误)。 daemonize这里没有必要,因为 debian 的服务是自动定义的。vacuum尽管如此,我认为logto那里也没有必要,chmod-socket并且uwsgi-socket- 所有这些都是由 debian 的服务定义的。我会证明这一点并完成这个答案。

尽管如此,通过尝试等,此配置是基本的,其他所有内容都应该自动拒绝或具有一些默认值或由 Django 本身:

[uwsgi]
plugins = python
chdir = /srv/www/usporion
pythonpath = /srv/www/usporion
wsgi-file = /srv/www/usporion/usporion/wsgi.py
于 2013-05-18T00:44:28.160 回答