2013-07-09 33 views
4

我试图按照本指南中的步骤操作:http://uwsgi-docs.readthedocs.org/en/latest/tutorials/Django_and_nginx.html建立uWSGI和Django应用程序

之前,我甚至去nginx的部分我想确保uWSGI正常工作

我的文件夹结构为SRV /网络/域/ projectdatabank/

项目数据库文件夹包含我的manage.py文件

我wsgi.py文件看起来像这样:

import os 
import sys 
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "databank.settings") 
from django.core.wsgi import get_wsgi_application 
application = get_wsgi_application() 

我进入projectdatabank文件夹,然后运行以下命令

uwsgi --http :8000 --wsgi-file projectdatabank/databank/wsgi.py 

,当我去的网页我得到这个错误

compiled with version: 4.4.7 20120313 (Red Hat 4.4.7-3) on 06 July 2013 00:16:13 
os: Linux-3.8.4-linode50 #1 SMP Mon Mar 25 15:50:29 EDT 2013 
nodename: 
machine: i686 
clock source: unix 
pcre jit disabled 
detected number of CPU cores: 8 
current working directory: /srv/www/databankinfo.com 
detected binary path: /usr/bin/uwsgi 
*** WARNING: you are running uWSGI without its master process manager *** 
your processes number limit is 1024 
your memory page size is 4096 bytes 
detected max file descriptor number: 1024 
lock engine: pthread robust mutexes 
uWSGI http bound on :8000 fd 4 
spawned uWSGI http 1 (pid: 10091) 
uwsgi socket 0 bound to TCP address 127.0.0.1:47129 (port auto-assigned) fd 3 
Python version: 2.6.6 (r266:84292, Feb 21 2013, 23:54:59) [GCC 4.4.7 20120313 (Red Hat 4.4.7-3)] 
*** Python threads support is disabled. You can enable it with --enable-threads *** 
Python main interpreter initialized at 0x8cf8598 
your server socket listen backlog is limited to 100 connections 
your mercy for graceful operations on workers is 60 seconds 
mapped 64000 bytes (62 KB) for 1 cores 
*** Operational MODE: single process *** 
WSGI app 0 (mountpoint='') ready in 1 seconds on interpreter 0x8cf8598 pid: 10090 (default app) 
*** uWSGI is running in multiple interpreter mode *** 
spawned uWSGI worker 1 (and the only) (pid: 10090, cores: 1) 
Traceback (most recent call last): 
    File "/usr/lib/python2.6/site-packages/django/core/handlers/wsgi.py", line 236, in __call__ 
    self.load_middleware() 
    File "/usr/lib/python2.6/site-packages/django/core/handlers/base.py", line 45, in load_middleware 
    for middleware_path in settings.MIDDLEWARE_CLASSES: 
    File "/usr/lib/python2.6/site-packages/django/conf/__init__.py", line 53, in __getattr__ 
    self._setup(name) 
    File "/usr/lib/python2.6/site-packages/django/conf/__init__.py", line 48, in _setup 
    self._wrapped = Settings(settings_module) 
    File "/usr/lib/python2.6/site-packages/django/conf/__init__.py", line 134, in __init__ 
    raise ImportError("Could not import settings '%s' (Is it on sys.path?): %s" % (self.SETTINGS_MODULE, e)) 
ImportError: Could not import settings 'databank.settings' (Is it on sys.path?): No module named databank.settings 
[pid: 10090|app: 0|req: 1/1] 66.56.35.151() {38 vars in 669 bytes} [Tue Jul 9 17:34:52 2013] GET/=> generated 0 bytes in 1 msecs (HTTP/1.1 500) 0 headers in 0 bytes (0 switches on core 0) 

但我知道,在settings.py存在与wsgi.py相同的目录

回答

4

您需要为您的uwsgi调用提供附加参数:

--chdir /path/to/your/project/ 
+1

谢谢!这让我一直,但现在我得到一个内部服务器错误,猜测谢谢你打开另一个问题,谢谢...再次感谢! – tareq