簡體   English   中英

使用 mod_wsgi 和 django 運行 Apache

[英]Run Apache with mod_wsgi and django

無法使用 Apache + Django 啟動服務器

操作系統:MacOS Catalina
Apache:2.4.43
Python:3.8
Django:3.0.7

由 Brew 的 Apache 使用。
mod_wsgi 通過 pip 安裝。

應用程序是通過標准命令創建的

django-admin startproject project_temp

調用命令時應用程序啟動

python manage.py runserver

在 mod_wsgi 開始時 - 一切正常

mod_wsgi-express start-server

當我啟動 Apache 時,服務器無法訪問。 在“本地主機:80”檢查。

告訴我,我需要做什么才能啟動服務器?

Httpd設置:

ServerRoot "/usr/local/opt/httpd"
ServerName localhost
Listen 80

LoadModule mpm_prefork_module lib/httpd/modules/mod_mpm_prefork.so
LoadModule authn_file_module lib/httpd/modules/mod_authn_file.so
LoadModule authn_core_module lib/httpd/modules/mod_authn_core.so
LoadModule authz_host_module lib/httpd/modules/mod_authz_host.so
LoadModule authz_groupfile_module lib/httpd/modules/mod_authz_groupfile.so
LoadModule authz_user_module lib/httpd/modules/mod_authz_user.so
LoadModule authz_core_module lib/httpd/modules/mod_authz_core.so
LoadModule access_compat_module lib/httpd/modules/mod_access_compat.so
LoadModule auth_basic_module lib/httpd/modules/mod_auth_basic.so
LoadModule reqtimeout_module lib/httpd/modules/mod_reqtimeout.so
LoadModule filter_module lib/httpd/modules/mod_filter.so
LoadModule mime_module lib/httpd/modules/mod_mime.so
LoadModule log_config_module lib/httpd/modules/mod_log_config.so
LoadModule env_module lib/httpd/modules/mod_env.so
LoadModule headers_module lib/httpd/modules/mod_headers.so
LoadModule setenvif_module lib/httpd/modules/mod_setenvif.so
LoadModule version_module lib/httpd/modules/mod_version.so
LoadModule unixd_module lib/httpd/modules/mod_unixd.so
LoadModule status_module lib/httpd/modules/mod_status.so
LoadModule autoindex_module lib/httpd/modules/mod_autoindex.so
LoadModule alias_module lib/httpd/modules/mod_alias.so
LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so
LoadModule wsgi_module /Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/site-packages/mod_wsgi/server/mod_wsgi-py38.cpython-38-darwin.so

<Directory />
    AllowOverride All
</Directory>

<Files ".ht*">
    Require all denied
</Files>

<IfModule log_config_module>
    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
    LogFormat "%h %l %u %t \"%r\" %>s %b" common

    <IfModule logio_module>
      LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
    </IfModule>

    CustomLog "/usr/local/var/log/httpd/access_log" common
</IfModule>

<IfModule headers_module>
    RequestHeader unset Proxy early
</IfModule>

<IfModule mime_module>
    TypesConfig /usr/local/etc/httpd/mime.types
    AddType application/x-compress .Z
    AddType application/x-gzip .gz .tgz
</IfModule>

<IfModule proxy_html_module>
    Include /usr/local/etc/httpd/extra/proxy-html.conf
</IfModule>

<IfModule ssl_module>
    SSLRandomSeed startup builtin
    SSLRandomSeed connect builtin
</IfModule>

WSGIScriptAlias / /Users/r/Projects/project_temp/project_temp/wsgi.py
WSGIPythonHome /Library/Frameworks/Python.framework/Versions/3.8

<VirtualHost localhost:80>
    LogLevel warn
    ErrorLog /Users/r/Projects/project_temp/log/error.log
    CustomLog /Users/r/Projects/project_temp/log/access.log combined

    <Directory /Users/r/Projects/project_temp/project_temp>
        <Files wsgi.py>
            Require all granted
        </Files>
    </Directory>
</VirtualHost>

我不太了解您的配置,但我的 Linux / Apache / WSGI 配置中確實有這一行:

WSGIDaemonProcess constr processes=2 threads=15 display-name=%{GROUP} python-home=/www/constr/venv python-path=/www/constr
WSGIProcessGroup constr

問題的解決方案

  1. 看了統計,誰在監聽端口——沒找到 httpd
  2. 使用 brew 運行 httpd。 使用 apachectl 啟動 - 它有效

django 還有其他問題,但這是另一個問題

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM