2016-02-24 6 views
10

ich ein django Projekt auf apache2 am Einsatz von mod_wsgi verwenden, aber das Problem ist, dass der Server-Seiten nicht dienen und es für 10 Minuten hängt, bevor ein Fehler geben:Django + mod_wsgi + apache2: Server hängt

End of script output before headers 

Das ist mein site-available/000-default.conf:

ServerAdmin [email protected] 
DocumentRoot /home/artfact/arTfact_webSite/ 
Alias /static /home/artfact/arTfact_webSite/static 
     <Directory /home/artfact/arTfact_webSite/static> 
     Order allow,deny 
     Allow from all 
     Require all granted 
     </Directory> 

     <Directory /home/artfact/arTfact_webSite> 
     Order allow,deny 
     Allow from all 
     <Files wsgi.py> 
         Require all granted 
     </Files> 
     </Directory> 

     WSGIDaemonProcess artfact_site processes=5 threads=25 python-path=/home/artfact/anaconda/lib/python2.7/site-packages/:/home/artfact/arTfact_webSite 

     WSGIProcessGroup artfact_site 
     WSGIScriptAlias//home/artfact/arTfact_webSite/arTfact_webSite/wsgi.py 

settings.py

""" 
Django settings for arTfact_webSite project. 

Generated by 'django-admin startproject' using Django 1.8.5. 

For more information on this file, see 
https://docs.djangoproject.com/en/1.8/topics/settings/ 

For the full list of settings and their values, see 
https://docs.djangoproject.com/en/1.8/ref/settings/ 
""" 

# Build paths inside the project like this: os.path.join(BASE_DIR, ...) 
import os 

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


# Quick-start development settings - unsuitable for production 
# See https://docs.djangoproject.com/en/1.8/howto/deployment/checklist/ 

# SECURITY WARNING: keep the secret key used in production secret! 
SECRET_KEY = xxxx 

# SECURITY WARNING: don't run with debug turned on in production! 
DEBUG = True 

ALLOWED_HOSTS = [] 


# Application definition 

INSTALLED_APPS = (
    'django.contrib.admin', 
    'django.contrib.auth', 
    'django.contrib.contenttypes', 
    'django.contrib.sessions', 
    'django.contrib.messages', 
    'django.contrib.staticfiles', 
    'website', 
    'blog', 
) 

MIDDLEWARE_CLASSES = (
    'django.contrib.sessions.middleware.SessionMiddleware', 
    'django.middleware.common.CommonMiddleware', 
    'django.middleware.csrf.CsrfViewMiddleware', 
    'django.contrib.auth.middleware.AuthenticationMiddleware', 
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware', 
    'django.contrib.messages.middleware.MessageMiddleware', 
    'django.middleware.clickjacking.XFrameOptionsMiddleware', 
    'django.middleware.security.SecurityMiddleware', 
) 

ROOT_URLCONF = 'arTfact_webSite.urls' 

TEMPLATES = [ 
    { 
     'BACKEND': 'django.template.backends.django.DjangoTemplates', 
     'DIRS': [], 
     'APP_DIRS': True, 
     'OPTIONS': { 
      'context_processors': [ 
       'django.template.context_processors.debug', 
       'django.template.context_processors.request', 
       'django.contrib.auth.context_processors.auth', 
       'django.contrib.messages.context_processors.messages', 
      ], 
     }, 
    }, 
] 

WSGI_APPLICATION = 'arTfact_webSite.wsgi.application' 


# Database 
# https://docs.djangoproject.com/en/1.8/ref/settings/#databases 

DATABASES = { 
    'default': { 
     'ENGINE': 'django.db.backends.sqlite3', 
     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 
    } 
} 


# Internationalization 
# https://docs.djangoproject.com/en/1.8/topics/i18n/ 

LANGUAGE_CODE = 'en-us' 

TIME_ZONE = 'Europe/Paris' 

USE_I18N = True 

USE_L10N = True 

USE_TZ = True 


# Static files (CSS, JavaScript, Images) 
# https://docs.djangoproject.com/en/1.8/howto/static-files/ 

STATIC_URL = '/static/' 
STATIC_ROOT = os.path.join(BASE_DIR, 'static') 

MEDIA_URL = '/media/' 
MEDIA_ROOT = os.path.join(BASE_DIR,'media') 

wsgi.py

""" 
WSGI config for arTfact_webSite project. 

It exposes the WSGI callable as a module-level variable named ``application``. 

For more information on this file, see 
https://docs.djangoproject.com/en/1.8/howto/deployment/wsgi/ 
""" 

from django.core.wsgi import get_wsgi_application 

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

application = get_wsgi_application() 

Projektstruktur

arTfact_webSite/ 
├── arTfact_webSite 
│   ├── __init__.py 
│   ├── __init__.pyc 
│   ├── settings.py 
│   ├── settings.pyc 
│   ├── urls.py 
│   ├── urls.pyc 
│   ├── wsgi.py 
│   └── wsgi.pyc 
├── blog 
├── static 
├── media 
└── website 
    ├── admin.py 
    ├── admin.pyc 
    ├── forms.py 
    ├── forms.pyc 
    ├── general_analyser.py 
    ├── general_analyser.pyc 
    ├── __init__.py 
    ├── __init__.pyc 
    ├── migrations 
    │   ├── __init__.py 
    │   └── __init__.pyc 
    ├── models.py 
    ├── models.pyc 
    ├── send_mail.py 
    ├── send_mail.pyc 
    ├── static 
    │   └── website 
    ├── templates 
    │   └── website 
    ├── tests.py 
    ├── tests.pyc 
    ├── urls.py 
    ├── urls.pyc 
    ├── views.py 
    └── views.pyc 

Im arTfact_webSite/urls.py

urlpatterns = [ 
    url(r'^/*', include('website.urls')), 
]+static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) 

In der Website/urls.py

urlpatterns = [ 
     url(r'^$', views.index, name='index'), 
    ] 

mache ich etwas falsch hier?

+0

'Ende der Skript-Ausgabe Der Fehler "Header" bedeutet, dass Ihre App abstürzt, bevor eine Antwort gesendet wird. Probieren Sie den folgenden Test. Stoppen Sie Apache, wechseln Sie zu/home/artfact/arTfact_webSite/arTfact_webSite und versuchen Sie, den Befehl python manage.py runserver auszuführen.Es sollte einen Entwicklungsserver starten, aber die Wahrscheinlichkeit ist groß, dass es Ihnen einen Fehler gibt, der anzeigt, was falsch läuft. –

Antwort

-1

Sie benötigen einen Server oder Serveralias in Ihrem Virtualhost-Block zu definieren:

ServerName www.example.com 

Ich gehe davon aus Apache oben configs sind in einem Virtualhost-Block wie folgt:

<VirtualHost *:80> 
... 
</VirtualHost> 
1

Es scheint, Sie haben eine ‚a‘ in Ihrer wsgi.py Datei zwischen den Zeilen

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "arTfact_webSite.settings") 
a 
application = get_wsgi_application() 

nicht sicher, ob dies auch in Ihrer aktuellen Datei.

0

Versuchen Sie den Befehl:

apachectl configtest

Dies soll Ihnen helfen, zu isolieren, was in Ihrer Apache-Konfiguration ausfällt. Siehe diesen Link für weitere Informationen: https://httpd.apache.org/docs/2.4/programs/apachectl.html

Wenn es Syntax OK "meldet, dann wissen Sie, dass es sich um eine Konfiguration Detail Problem ist eher als ein Konfigurationssyntax Problem.

Andernfalls wäre die Veröffentlichung Ihrer Apache2-Protokolle hilfreich.