소스 검색

Fixed #25203 -- Documented how to pass Apache environment variables to Django.

Paul Rentschler 9 년 전
부모
커밋
47016d4322
1개의 변경된 파일41개의 추가작업 그리고 0개의 파일을 삭제
  1. 41 0
      docs/howto/deployment/wsgi/modwsgi.txt

+ 41 - 0
docs/howto/deployment/wsgi/modwsgi.txt

@@ -125,6 +125,47 @@ mode`_.
 
 .. _details on setting up daemon mode: http://code.google.com/p/modwsgi/wiki/QuickConfigurationGuide#Delegation_To_Daemon_Process
 
+Apache environment variables
+============================
+
+If you want to specify a different Django settings file or additional variables
+for your Django application via the Apache configuration, you would do it like
+this:
+
+.. code-block:: apache
+
+    SetEnv DB_USER dbusername
+    SetEnv DJANGO_SETTINGS_MODULE mysite.alternate-settings
+
+The ``SetEnv`` directive creates Apache environment variables instead of OS
+environment variables, so you will need to replace the default ``wsgi.py`` file
+with::
+
+    import os
+
+    from django.core.wsgi import get_wsgi_application
+
+    # A tuple of Apache environment variables to pass through to Django.
+    env_variables_to_pass = ('DB_USER', )
+
+    def application(environ, start_response):
+        """
+        Wrapper for the WSGI application that passes environment variables.
+        """
+        os.environ['DJANGO_SETTINGS_MODULE'] = environ.get('DJANGO_SETTINGS_MODULE', 'mysite.settings')
+        for var in env_variables_to_pass:
+            os.environ[var] = environ.get(var, '')
+        return get_wsgi_application()(environ, start_response)
+
+Now you can specify a new settings file in Apache using the
+``SetEnv DJANGO_SETTINGS_MODULE ...`` line, and if that setting isn't
+specified, it uses ``'mysite.settings'`` as a default. You'll want to change
+``mysite.settings`` to reference your own ``settings.py`` module.
+
+Additionally, you can use the ``env_variables_to_pass`` tuple to specify any
+other Apache environment variables, such as database login credentials, that
+should be passed along to the Django application as OS environment variables.
+
 .. _serving-files:
 
 Serving files