Django、Virtualenv、nginx + uwsgiインポートモジュールwsgiエラー

私のdjangoプロジェクトをnginx、virtualenv、およびuwsgiを使用してステージングサーバーにセットアップしようとしていますが、インポートモジュールwsgiエラーが続いています。

もし私が答えを見つけることができるコミュニティがあれば...あらかじめありがとう。

これは私の設定ファイルです:

私のdjangoプロジェクトのuwsgi.py:

import os
import sys 
import site

site.addsitedir(os.path.join(os.environ['WORKON_HOME'],'project/lib/python2.6/site-packages'))
sys.path.append(os.path.abspath(os.path.dirname(__file__)))
sys.path.append(os.path.join(os.path.realpath(os.path.dirname(__file__)), '../../../'))
sys.path.append(os.path.join(os.path.realpath(os.path.dirname(__file__)), '../../'))

os.environ['DJANGO_SETTINGS_MODULE'] = 'project.configs.staging.settings'

import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

Nginxの設定

# Nginxの設定 for project.maumercado.com

server {
    server_name project.maumercado.com;
    access_log /home/ubuntu/logs/project/nginx/access.log;
    error_log /home/ubuntu/logs/project/nginx/error.log;

    location/{
            uwsgi_pass unix:/tmp/uwsgi.sock;
            include /etc/nginx/uwsgi_params;
    }

    location /static {
            root /home/ubuntu/django-projects/project/project/media;
    }
    location /media {
            root /home/ubuntu/django-projects/project/project/media;
    }
}

と私のuwsgi.conf

# file: /etc/init/uwsgi.conf 
description "uWSGI starter"

start on (local-filesystems and runlevel [2345])
stop on runlevel [016]

respawn

# home - is the path to our virtualenv directory
# pythonpath - the path to our django application
# module - the wsgi handler python script

exec /home/ubuntu/ve/project/bin/uwsgi \
--uid www-data \
--pythonpath /home/ubuntu/django-projects/project/project/configs/staging/ \
--socket /tmp/uwsgi.sock \
--chmod-socket \
--module wsgi \
--logdate \
--optimize 2 \
--processes 2 \
--master \
--logto /home/ubuntu/logs/project/uwsgi.log

Nginxのログにはaccess.logに500以外のものは記載されていないので、uwsgi.logをheresします:

Mon Feb  6 13:58:23 2012 - *** Starting uWSGI 1.0.2.1 (32bit) on [Mon Feb  6 13:58:23 2012] ***
Mon Feb  6 13:58:23 2012 - compiled with version: 4.4.5 on 06 February 2012 12:32:36
Mon Feb  6 13:58:23 2012 - current working directory: /
Mon Feb  6 13:58:23 2012 - detected binary path: /home/ubuntu/ve/project/bin/uwsgi
Mon Feb  6 13:58:23 2012 - setuid() to 1000
Mon Feb  6 13:58:23 2012 - your memory page size is 4096 bytes
Mon Feb  6 13:58:23 2012 - chmod() socket to 666 for lazy and brave users
Mon Feb  6 13:58:23 2012 - uwsgi socket 0 bound to UNIX address /tmp/uwsgi.sock fd 3
Mon Feb  6 13:58:23 2012 - Python version: 2.6.6 (r266:84292, Sep 15 2010, 16:02:57)  [GCC 4.4.5]
Mon Feb  6 13:58:23 2012 - Set PythonHome to /home/ubuntu/ve/project
Mon Feb  6 13:58:23 2012 - Python main interpreter initialized at 0x9a9d740
Mon Feb  6 13:58:23 2012 - your server socket listen backlog is limited to 100 connections
Mon Feb  6 13:58:23 2012 - *** Operational MODE: preforking ***
Mon Feb  6 13:58:23 2012 - added /home/ubuntu/django-projects/project/ to pythonpath.
ImportError: No module named wsgi
Mon Feb  6 13:58:23 2012 - unable to load app 0 (mountpoint='') (callable not found or import error)
Mon Feb  6 13:58:23 2012 - *** no app loaded. going in full dynamic mode ***
Mon Feb  6 13:58:23 2012 - *** uWSGI is running in multiple interpreter mode ***
Mon Feb  6 13:58:23 2012 - spawned uWSGI master process (pid: 551)
Mon Feb  6 13:58:23 2012 - spawned uWSGI worker 1 (pid: 588, cores: 1)
Mon Feb  6 13:58:23 2012 - spawned uWSGI worker 2 (pid: 589, cores: 1)

私は私のプロジェクトをセットアップする方法はそれと何か関係があるかどうかはわかりませんが、とにかく私はdjangoユーティリティをリダイレクトするために使用する管理ファイルをheres:

manage.sh

#!/bin/bash

python ./project/configs/${DEPLOYMENT_TARGET:="common"}/manage.py $*

これが私がdjangoプロジェクトを設定した方法です。

project
|-manage.sh -> this fellow is redirected to settings.py (production, common or staging)
|-requirements.txt
|-README
|-dashbard.py
|-project.sqlite
|- project/
    |- apps
        |- accounts
        |-other internal apps
    |- configs 
        |- common -> for local development
            |-settings.py
            |-manage.py
            |-urls
        |-staging
            |-manage.py
            |-settings.py
            |-wsgi.py
            |-logging.conf
        |-production
            |-manage.py
            |-settings.py
            |-wsgi.py
            |-logging.conf
    |-media
    |-templates
6

2 答え

wsgi.pyを次のように更新しました:

import os
import sys
import site

site.addsitedir(os.path.join('/home/ubuntu/ve','project/lib/python2.6/site-packages'))
sys.path.append(os.path.abspath(os.path.dirname(__file__)))
sys.path.append(os.path.join(os.path.realpath(os.path.dirname(__file__)), '../../../'))
sys.path.append(os.path.join(os.path.realpath(os.path.dirname(__file__)), '../../'))

os.environ['DJANGO_SETTINGS_MODULE'] = 'project.configs.staging.settings'

import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

私のuwsgi.confファイルは次のようになります:

# file: /etc/init/uwsgi.conf
description "uWSGI starter"

start on (local-filesystems and runlevel [2345])
stop on runlevel [016]

respawn

# home - is the path to our virtualenv directory
# pythonpath - the path to our django application
# module - the wsgi handler python script

exec /home/ubuntu/ve/project/bin/uwsgi \
--uid ubuntu \
--pythonpath /home/ubuntu/django-projects/project/project/configs/staging \
-H /home/ubuntu/ve/project \
--socket /tmp/uwsgi.sock \
--chmod-socket 644 \
--module wsgi \
--logdate \
--optimize 2 \
--processes 2 \
--master \
--logto /home/ubuntu/logs/project/uwsgi.log

そして、私のnginxサイト利用可能なファイルは次のようになります:

# file: /etc/nginx/sites-available/yourdomain.com
# nginx configuration for project.maumercado.com

server {
        listen 80;
        charset utf-8;
        server_name project.maumercado.com;
        access_log /home/ubuntu/logs/project/nginx/access.log;
        error_log /home/ubuntu/logs/project/nginx/error.log;

        location ^~ /cache/ {
                root /home/ubuntu/django-projects/project/project/media;
                expires max;
        }

        location/{
                uwsgi_pass unix:/tmp/uwsgi.sock;
                include /etc/nginx/uwsgi_params;
        }
}

そして、今、完璧な動作をしています。私は、CSSファイルの中で〜のような奇妙な文字が使われているので、スタイルにいくつかの問題がありました。

今私は、uwsgiを使って同じサーバーでさらに多くのプロジェクトを実行する必要があるときに、どうすればいいのかを知りたいと思いますか?

5
追加された
私が複数のプロジェクトで行うことは、uwsgi Debianパッケージを使用することです。 initスクリプト、いくつかのデフォルトの.ini設定ファイルが付属しており、それぞれのプロジェクトを管理しています。各ファイルには設定が必要で、それぞれに異なるソケットが必要です(デフォルトで処理されます)。これらは同じシステム上でうまく動作します。 Debian上にいなくても、Debianパッケージのinitスクリプトと設定のレイアウトは引き続き使用できます: ftp.de.debian.org/debian/pool/main/u/uwsgi/…
追加された 著者 freb,

wsgi.pyファイルを含むディレクトリをpythonpathに追加してください(pythonpathディレクティブを無制限に指定できます)

1
追加された
ここでは、wsgi.pyファイルを保存している場所を確認しています。それとも別の意味ですか?ありがとう!
追加された 著者 maumercado,
ああ、私はそれを持って...はい実際には、その方法です、私はそこに置く "project_apps"フォルダは実際にプロジェクトと呼ばれ、病気を編集!
追加された 著者 maumercado,
/ home/ubuntu/django-projects/project/project/configs/stagingの代わりに/ home/ubuntu/django-projects/project/project_apps/configs/st&
追加された 著者 roberto,