Ошибка Apache mod wsgi: запрещено у вас нет разрешения на доступ / на этом сервере
Я использую Ubuntu 10.04.
Я создаю проект django под /home/wong2/Code/python/django2/
имени atest
и создайте файл wsgi setting.wsgi
в том же каталоге
Вот содержание setting.wsgi
:
import os
import sys
path = '/home/wong2/Code/python/django2'
if path not in sys.path:
sys.path.append(path)
os.environ["DJANGO_SETTINGS_MODULE"] = "atest.settings"
from django.core.handlers.wsgi import WSGIHandler
application = WSGIHandler()
и вот что я добавляю в свой httpd.conf:
<VirtualHost *:80>
ServerName localhost
WSGIScriptAlias / /home/wong2/Code/python/django2/setting.wsgi
<Directory />
Options FollowSymLinks
AllowOverride None
Order deny,allow
Allow from all
</Directory>
<Directory "/home/wong2/Code/python/django2/atest">
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
проблема в том, когда я посещаю http://localhost, он скажет
запрещен
у вас нет разрешения на доступ / на этом сервер.
Спасибо большое.
5 ответов
второй блок каталога не соответствует тому, где установлен файл сценария WSGI. Это очень плохая практика, хотя придерживаться файла сценария WSGI в месте, где существует исходный код или другие конфиденциальные файлы, т. е. же каталог или подкаталог. Вместо этого вы должны вставить его в собственный подкаталог. Таким образом:
WSGIScriptAlias / /home/wong2/Code/python/django2/atest/apache/setting.wsgi
<Directory "/home/wong2/Code/python/django2/atest/apache">
Order allow,deny
Allow from all
</Directory>
Итак, создайте подкаталог "apache" в разделе "atest". Ход установки.wsgi "в этот подкаталог "apache" и измените конфигурацию на выше.
ваша проблема также может быть вызвана ограничительными разрешениями на вашем домашнем каталоге, поскольку Apache не может видеть внутри.
Go watch:
http://code.google.com/p/modwsgi/wiki/WhereToGetHelp?tm=6#Conference_Presentations
как он объясняет эти проблемы с разрешениями, а также такие проблемы, как, где вставить ваш код и файл сценария WSGI.
также читайте:
С Django 1.5+, вы должны использовать предлагаемый способ описан в документации:
WSGIScriptAlias / /path/to/mysite.com/mysite/wsgi.py
WSGIPythonPath /path/to/mysite.com
<Directory /path/to/mysite.com/mysite>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
https://docs.djangoproject.com/en/1.7/howto/deployment/wsgi/modwsgi/
у меня была такая же проблема из-за ограничения прав доступа к файлу.
по умолчанию пользователь вашей домашней папки имеет настройки:
ls -l /home/
drwx------ 36 пользователь пользователь 12288 Nov 28 20: 56 user
означает, что никто, кроме вас, не может даже просматривать эту папку.
добавление опции execute в папку исправлена моя проблема
chmod o+x /home/user/
ls -l /home/
drwx - - - - - x 36 user user 12288 Nov 28 20: 56 user
попробовать http://localhost/index.HTML-код показывает ли это страницу apache?
Если wsgi настроен на root правильно, это не будет.
вы получаете это сообщение об ошибке, потому что вы можете запросить веб-сервер для списка каталогов www folder
edit:
мои проекты всегда в
/ var/pyproj/ / pysrc/ и серверные файлы, которые я вставляю /var / py_proj / / сервер/
вот мой перейти к wsgi скрипт
import os, sys
import logging
logger =logging.getLogger("")
logger.setLevel(logging.DEBUG)
handler = logging.StreamHandler(sys.stderr)
handler.setLevel(logging.DEBUG)
formatter = logging.Formatter('%(levelname)-8s %(messages)s')
handler.setFormatter(formatter)
logger.addHandler(handler)
sys.stdout = sys.stderr
from os.path import abspath, dirname, join
import site
PROJECT_ROOT = abspath(join(dirname(__file__), "../pysrc"))
SETTINGS_LOC = abspath(join(PROJECT_ROOT, ''))
site.addsitedir(SETTINGS_LOC)
os.environ["DJANGO_SETTINGS_MODULE"] = "settings"
from django.core.management import setup_environ
import settings
setup_environ(settings)
sys.path.insert(0, join(PROJECT_ROOT, "apps"))
from django.core.handlers.wsgi import WSGIHandler
application = WSGIHandler()
и я использую vhost.conf
WSGIDaemonProcess pinax_demo user=www-data group=www-data threads=10 python-path=/var/.virtualenvs/pinax_demo/lib/python2.6/site-packages
<Directory /var/py_proj/pinax_demo/server/>
Order deny,allow
Allow from all
</Directory>
Alias /pinax_demo /var/py_proj/pinax_demo/server/pinax_demo.wsgi
<Location /pinax_demo/>
#WSGIProcessGroup must match the WSGIDaemonProcess
WSGIProcessGroup pinax_demo
SetHandler wsgi-script
Options +ExecCGI
</Location>
который я включаю в папку "доступные сайты" в файле, который выглядит следующим образом
<VirtualHost *:8080>
DocumentRoot /var/www/
<Directory /var/www/>
Order deny,allow
Allow from all
Options -Indexes FollowSymLinks
DirectoryIndex index.php
AllowOverride None
</Directory>
ServerAdmin oto@example.com
LogLevel error
ErrorLog /var/srv_logs/apache_error.log
CustomLog /var/srv_logs/apache_access.log combined
#insert
Include /var/py_proj/pinax_demo/server/vhost.conf
Include /var/py_proj/<other>/server/vhost.conf
Include /var/py_proj/<other>/server/vhost.conf
</VirtualHost>
httpd.conf пуст. Apache также ужасен при отправке статических файлов, поэтому у меня есть настройка apache на порту 8080 и настройка nginx на порту 80, который перенаправляет apache. Вы должны иметь возможность просто изменить порт на моих сайтах-доступный файл, чтобы запустить его без nginx, но я бы не стал жить так
вы можете получить сюрприз, где ваш WSGI имеет свой домашний каталог! На моей, по общему признанию, наивной установке wsgi_mod это / - я был так удивлен, что мне пришлось написать этот скрипт, чтобы убедиться:
import os
def application(environ, start_response):
status = '200 OK'; e=os.listdir(os.getcwd())
output = '''WSGI %s<hr>'''%(e)
response_headers = [('Content-type', 'text/html'),
('Content-Length', str(len(output)))]
start_response(status, response_headers)
return [output]
это означает, что импортированным приложениям потребуется полный путь, например:
sys.path.append('/home/foo/www/Forms')
from DataCommon import page
это рекомендуемый (Google) подход к этому:
import sys; path='/home/foo/www/Forms';
if path not in sys.path: sys.path.append(path)