我正试图以Debug=True
模式在VPS上启动我的应用。
我正在使用Django 1.6和Python 2.7。
我尝试过简单的wscgi 脚本,发现它运行良好(基本上返回200和文本/ plain中的“Hello world”) 到浏览器。这是我的配置:
虚拟主机配置
<VirtualHost *:80>
ServerName subdomain.domain.info
ServerAlias www.subdomain.sigizmund.info
WSGIScriptAlias / /var/www/subdomain/index.wsgi
Alias /static/ /var/www/subdomain/static/
ErrorLog /tmp/subdomain.error.log
CustomLog /tmp/subdomain.custom.log common
LogLevel debug
<Location "/static/">
Options -Indexes
</Location>
<Directory /home/sgzmd/code/myproject>
Order deny,allow
Allow from all
</Directory>
</VirtualHost>
index.wsgi
import os
import sys
import site
# Add the site-packages of the chosen virtualenv to work with
site.addsitedir('/home/sgzmd/.virtualenvs/myenv/local/lib/python2.7/site-packages')
PROJECT_PATH = '/home/sgzmd/code/myproject'
if PROJECT_PATH not in sys.path:
sys.path.insert(0, PROJECT_PATH)
os.environ['DJANGO_SETTINGS_MODULE'] = 'myproject.settings'
# Activate your virtual env
activate_env=os.path.expanduser("~/.virtualenvs/myenv/bin/activate_this.py")
execfile(activate_env, dict(__file__=activate_env))
import django.core.handlers.wsgi
import cStringIO
import pprint
class LoggingMiddleware:
def __init__(self, application):
self.__application = application
def __call__(self, environ, start_response):
errors = environ['wsgi.errors']
pprint.pprint(('REQUEST', environ), stream=errors)
def _start_response(status, headers, *args):
pprint.pprint(('RESPONSE', status, headers), stream=errors)
return start_response(status, headers, *args)
return self.__application(environ, _start_response)
application = LoggingMiddleware(django.core.handlers.wsgi.WSGIHandler())
我有以下日志记录输出:http://pastebin.com/SnZVEeT1(来自LoggingMiddleware)和/var/log/django/error.log
正在创建和重新创建时,仍然完全为空。
我想通过编辑项目的settings.py来加载应用,其中的内容可以在这里找到:http://pastebin.com/Byr8RStb
感谢任何指针和想法,因为我现在基本上没有选择。
答案 0 :(得分:0)
这不适用于开始:
activate_env=os.path.expanduser("~/.virtualenvs/myenv/bin/activate_this.py")
这是因为Apache以特殊用户身份运行,并且〜不会扩展到您自己设置virtualenv的用户。
不知道这是否相关。