让 Django 项目在 mod_wsgi 中运行时出现问题

Posted

技术标签:

【中文标题】让 Django 项目在 mod_wsgi 中运行时出现问题【英文标题】:Problems getting Django project to run in mod_wsgi 【发布时间】:2017-03-01 17:35:15 【问题描述】:

我在让我的 django 项目通过 mod_wsgi 正确服务时遇到一些问题。

这是我第一次尝试这样的事情,所以请原谅任何菜鸟的错误。

我目前遇到的错误如下:

[Wed Oct 19 16:24:23 2016] [error] [client 140.225.0.153] mod_wsgi (pid=20418): Exception occurred processing WSGI script '/opt/badgr/code/apps/mainsite/wsgi.py'.
[Wed Oct 19 16:24:23 2016] [error] [client 140.225.0.153] Traceback (most recent call last):
[Wed Oct 19 16:24:23 2016] [error] [client 140.225.0.153]   File "/opt/badgr/code/apps/mainsite/wsgi.py", line 14, in <module>
[Wed Oct 19 16:24:23 2016] [error] [client 140.225.0.153]     from django.core.wsgi import get_wsgi_application
[Wed Oct 19 16:24:23 2016] [error] [client 140.225.0.153] ImportError: No module named wsgi

主项目目录在这里:

/opt/badgr/

该项目有自己的 virtualenv 位于此处:

/opt/badgr/env/lib/python2.7/site-packages

我的 wsgi.py 文件:

"""
WSGI config for badgr 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.7/howto/deployment/wsgi/
"""

import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mainsite.settings")

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

我还有一个位于/etc/httpd/conf.d/django.conf 文件:

Alias /static /opt/badgr/code/staticfiles
<Directory /opt/badgr/code/staticfiles>
</Directory>


<Directory /opt/badgr/code/apps/mainsite/>
    <Files wsgi.py>
    </Files>
</Directory>

WSGISocketPrefix /var/run/wsgi/wsgi
WSGIDaemonProcess badgr python-path=/opt/badgr:/opt/badgr/env/lib/python2.7/site-packages/
WSGIProcessGroup badgr
WSGIScriptAlias / /opt/badgr/code/apps/mainsite/wsgi.py

据我所知,mod_wsgi 已正确安装在 virtualenv 中,所以我不确定为什么在尝试通过 http 连接到站点时看到此错误。

这是我的 httpd.conf:

   ServerTokens OS
 /mod/mpm_common.html#lockfile>);
    ServerRoot "/etc/httpd"
    PidFile run/httpd.pid
    Timeout 60
    KeepAlive Off
    MaxKeepAliveRequests 100
    KeepAliveTimeout 15
    <IfModule prefork.c>
    StartServers       8
    MinSpareServers    5
    MaxSpareServers   20
    ServerLimit      256
    MaxClients       256
    MaxRequestsPerChild  4000
    </IfModule>
    <IfModule worker.c>
    StartServers         4
    MaxClients         300
    MinSpareThreads     25
    MaxSpareThreads     75 
    ThreadsPerChild     25
    MaxRequestsPerChild  0
    </IfModule>
    Listen 80
    LoadModule auth_basic_module modules/mod_auth_basic.so
    LoadModule auth_digest_module modules/mod_auth_digest.so
    LoadModule authn_file_module modules/mod_authn_file.so
    LoadModule authn_alias_module modules/mod_authn_alias.so
    LoadModule authn_anon_module modules/mod_authn_anon.so
    LoadModule authn_dbm_module modules/mod_authn_dbm.so
    LoadModule authn_default_module modules/mod_authn_default.so
    LoadModule authz_host_module modules/mod_authz_host.so
    LoadModule authz_user_module modules/mod_authz_user.so
    LoadModule authz_owner_module modules/mod_authz_owner.so
    LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
    LoadModule authz_dbm_module modules/mod_authz_dbm.so
    LoadModule authz_default_module modules/mod_authz_default.so
    LoadModule ldap_module modules/mod_ldap.so
    LoadModule authnz_ldap_module modules/mod_authnz_ldap.so
    LoadModule include_module modules/mod_include.so
    LoadModule log_config_module modules/mod_log_config.so
    LoadModule logio_module modules/mod_logio.so
    LoadModule env_module modules/mod_env.so
    LoadModule ext_filter_module modules/mod_ext_filter.so
    LoadModule mime_magic_module modules/mod_mime_magic.so
    LoadModule expires_module modules/mod_expires.so
    LoadModule deflate_module modules/mod_deflate.so
    LoadModule headers_module modules/mod_headers.so
    LoadModule usertrack_module modules/mod_usertrack.so
    LoadModule setenvif_module modules/mod_setenvif.so
    LoadModule mime_module modules/mod_mime.so
    LoadModule dav_module modules/mod_dav.so
    LoadModule status_module modules/mod_status.so
    LoadModule autoindex_module modules/mod_autoindex.so
    LoadModule info_module modules/mod_info.so
    LoadModule dav_fs_module modules/mod_dav_fs.so
    LoadModule vhost_alias_module modules/mod_vhost_alias.so
    LoadModule negotiation_module modules/mod_negotiation.so
    LoadModule dir_module modules/mod_dir.so
    LoadModule actions_module modules/mod_actions.so
    LoadModule speling_module modules/mod_speling.so
    LoadModule userdir_module modules/mod_userdir.so
    LoadModule alias_module modules/mod_alias.so
    LoadModule substitute_module modules/mod_substitute.so
    LoadModule rewrite_module modules/mod_rewrite.so
    LoadModule proxy_module modules/mod_proxy.so
    LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
    LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
    LoadModule proxy_http_module modules/mod_proxy_http.so
    LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
    LoadModule proxy_connect_module modules/mod_proxy_connect.so
    LoadModule cache_module modules/mod_cache.so
    LoadModule suexec_module modules/mod_suexec.so
    LoadModule disk_cache_module modules/mod_disk_cache.so
    LoadModule cgi_module modules/mod_cgi.so
    LoadModule version_module modules/mod_version.so
    Include conf.d/*.conf
    User apache
    Group apache
    ServerAdmin root@localhost
    UseCanonicalName Off
    DocumentRoot "/var/www/html"

    <Directory />
        Options FollowSymLinks
        AllowOverride None
    </Directory>

    <Directory "/var/www/html">

        Options Indexes FollowSymLinks
        AllowOverride None
        Order allow,deny
        Allow from all

    </Directory>


    <IfModule mod_userdir.c>

        UserDir disabled

    </IfModule>




    DirectoryIndex index.html index.html.var


    AccessFileName .htaccess


    <Files ~ "^\.ht">
        Order allow,deny
        Deny from all
        Satisfy All
    </Files>

    TypesConfig /etc/mime.types

    DefaultType text/plain

    <IfModule mod_mime_magic.c>
        MIMEMagicFile conf/magic
    </IfModule>

    HostnameLookups Off

    ErrorLog logs/error_log

    LogLevel warn

    LogFormat "%h %l %u %t \"%r\" %>s %b \"%Refereri\" \"%User-Agenti\"" combined
    LogFormat "%h %l %u %t \"%r\" %>s %b" common
    LogFormat "%Refereri -> %U" referer
    LogFormat "%User-agenti" agent


    CustomLog logs/access_log combined

    ServerSignature On


    Alias /icons/ "/var/www/icons/"

    <Directory "/var/www/icons">
        Options Indexes MultiViews FollowSymLinks
        AllowOverride None
        Order allow,deny
        Allow from all
    </Directory>


    <IfModule mod_dav_fs.c>
        # Location of the WebDAV lock database.
        DAVLockDB /var/lib/dav/lockdb
    </IfModule>

    ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"

    <Directory "/var/www/cgi-bin">
        AllowOverride None
        Options None
        Order allow,deny
        Allow from all
    </Directory>


    IndexOptions FancyIndexing VersionSort NameWidth=* HTMLTable Charset=UTF-8

    AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip

    AddIconByType (TXT,/icons/text.gif) text/*
    AddIconByType (IMG,/icons/image2.gif) image/*
    AddIconByType (SND,/icons/sound2.gif) audio/*
    AddIconByType (VID,/icons/movie.gif) video/*

    AddIcon /icons/binary.gif .bin .exe
    AddIcon /icons/binhex.gif .hqx
    AddIcon /icons/tar.gif .tar
    AddIcon /icons/world2.gif .wrl .wrl.gz .vrml .vrm .iv
    AddIcon /icons/compressed.gif .Z .z .tgz .gz .zip
    AddIcon /icons/a.gif .ps .ai .eps
    AddIcon /icons/layout.gif .html .shtml .htm .pdf
    AddIcon /icons/text.gif .txt
    AddIcon /icons/c.gif .c
    AddIcon /icons/p.gif .pl .py
    AddIcon /icons/f.gif .for
    AddIcon /icons/dvi.gif .dvi
    AddIcon /icons/uuencoded.gif .uu
    AddIcon /icons/script.gif .conf .sh .shar .csh .ksh .tcl
    AddIcon /icons/tex.gif .tex
    AddIcon /icons/bomb.gif /core

    AddIcon /icons/back.gif ..
    AddIcon /icons/hand.right.gif README
    AddIcon /icons/folder.gif ^^DIRECTORY^^
    AddIcon /icons/blank.gif ^^BLANKICON^^


    DefaultIcon /icons/unknown.gif

    ReadmeName README.html
    HeaderName HEADER.html

    IndexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t

    AddLanguage ca .ca
    AddLanguage cs .cz .cs
    AddLanguage da .dk
    AddLanguage de .de
    AddLanguage el .el
    AddLanguage en .en
    AddLanguage eo .eo
    AddLanguage es .es
    AddLanguage et .et
    AddLanguage fr .fr
    AddLanguage he .he
    AddLanguage hr .hr
    AddLanguage it .it
    AddLanguage ja .ja
    AddLanguage ko .ko
    AddLanguage ltz .ltz
    AddLanguage nl .nl
    AddLanguage nn .nn
    AddLanguage no .no
    AddLanguage pl .po
    AddLanguage pt .pt
    AddLanguage pt-BR .pt-br
    AddLanguage ru .ru
    AddLanguage sv .sv
    AddLanguage zh-CN .zh-cn
    AddLanguage zh-TW .zh-tw

    LanguagePriority en ca cs da de el eo es et fr he hr it ja ko ltz nl nn no pl pt pt-BR ru sv zh-CN zh-TW


    ForceLanguagePriority Prefer Fallback

    AddDefaultCharset UTF-8

    AddType application/x-compress .Z
    AddType application/x-gzip .gz .tgz

    AddType application/x-x509-ca-cert .crt
    AddType application/x-pkcs7-crl    .crl

    AddHandler type-map var
    AddType text/html .shtml
    AddOutputFilter INCLUDES .shtml


    Alias /error/ "/var/www/error/"

    <IfModule mod_negotiation.c>
    <IfModule mod_include.c>
        <Directory "/var/www/error">
            AllowOverride None
            Options IncludesNoExec
            AddOutputFilter Includes html
            AddHandler type-map var
            Order allow,deny
            Allow from all
            LanguagePriority en es de fr
            ForceLanguagePriority Prefer Fallback
        </Directory>


    </IfModule>
    </IfModule>


    BrowserMatch "Mozilla/2" nokeepalive
    BrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0
    BrowserMatch "RealPlayer 4\.0" force-response-1.0
    BrowserMatch "Java/1\.0" force-response-1.0
    BrowserMatch "JDK/1\.0" force-response-1.0


    BrowserMatch "Microsoft Data Access Internet Publishing Provider" redirect-carefully
    BrowserMatch "MS FrontPage" redirect-carefully
    BrowserMatch "^WebDrive" redirect-carefully
    BrowserMatch "^WebDAVFS/1.[0123]" redirect-carefully
    BrowserMatch "^gnome-vfs/1.0" redirect-carefully
    BrowserMatch "^XML Spy" redirect-carefully
    BrowserMatch "^Dreamweaver-WebDAV-SCM1" redirect-carefully

WSGI 是通过 conf.d 中的文件加载的:

LoadModule wsgi_module modules/mod_wsgi.so

除了删除 cmets 之外,我并没有在 HTTPD.conf 文件中进行太多编辑,因此我可以将其安装在此处。

我也不确定为什么 python 似乎为 httpd 运行 2.6.# 而不是 2.7。

感谢任何想法或其他信息。如果我应该提供其他任何东西,也请告诉我。

【问题讨论】:

【参考方案1】:

关于django.core.wsgi 的错误是因为您安装了一个非常旧的 Django 版本,比您的项目设置的版本更旧。

这可能是因为您的 mod_wsgi 是为 Python 2.6 编译的,并且您在该 Python 安装中安装了较旧的 Django 版本。

如果您想使用 Python 2.7,您必须使用为 Python 2.7 编译的 mod_wsgi 重新安装。您不能强制为 Python 2.6 编译的 mod_wsgi 使用 Python 2.7 的虚拟环境。

【讨论】:

感谢格雷厄姆的回复, 如何重新安装它。通过 pip 安装时是否需要使用某种标志,还是需要从头开始完全编译 mod_wsgi? 啊,我只需要用 yum 安装 python27-mod_wsgi,我相信。将拍摄并张贴在这里。 好的,在完成上述操作后,我仍然遇到同样的错误。我非常肯定该模块也正在加载。我应该试试 Greg 的建议吗? [Thu Oct 20 14:16:55.576488 2016] [lbmethod_heartbeat:notice] [pid 23095] AH02282: No slotmem from mod_heartmonitor [Thu Oct 20 14:16:55.576555 2016] [:warn] [pid 23095] mod_wsgi: Compiled for Python/2.7.5. [Thu Oct 20 14:16:55.576564 2016] [:warn] [pid 23095] mod_wsgi: Runtime using Python/2.7.8. [Thu Oct 20 14:16:55.580256 2016] [mpm_prefork:notice] [pid 23095] AH00163: Apache/2.4.18 (Red Hat) mod_wsgi/3.4 Python/2.7.8 configured -- resuming normal operations [Thu Oct 20 14:16:55.580281 2016] [core:notice] [pid 23095] AH00094: Command line: '/opt/rh/httpd24/root/usr/sbin/httpd'【参考方案2】:

注意:我提供了这个在 pip 中使用 mod_wsgi 的答案,因为我最近必须自己这样做才能使用 Python 3 在 FreeBSD 中运行它。通常不这样做,但它应该可以工作。

如果您想从 pip 安装 mod_wsgi,那么您应该为 Apache 提供 mod_wsgi 的正确路径,或者将它创建的模块 pip 安装到 Apache 安装中。如果您使用 apt-get 或 pkg 或 BSD 端口在您的系统上运行它,那么请听听 Graham 的明智建议。

还有其他一些事情可能同时出错,但我认为最接近的错误是您的应用程序无法导入 wsgi。您应该通过以下方式进入您的环境:

cd /opt/badgr
. env/bin/activate

如果失败,请尝试source env/bin/activate

然后安装 mod_wsgi:

pip install mod_wsgi

这将安装一个名为 mod_wsgi-express 的脚本,它允许您从命令行将 Apache/mod_wsgi 作为开发服务器运行。该脚本还可以帮助您将它编译的模块安装到您的 Apache 中。

首先我们必须处理 Apache 已经从系统包中安装了 mod_wsgi 模块的事实。最好的办法是卸载 mod_wsgi 的系统包。这可能会使用 wsgi_module 的 LoadModule 行删除 conf.d 中的该文件。

下一次运行:

sudo mod_wsgi-express install-module

这应该将模块复制到 Apache 模块目录并输出两行带有 LoadModule 和 WSGIPythonHome 指令的行。在 conf.d 目录下添加一个新的 wsgi.conf 文件并将这两行添加到其中。重启 Apache。

从您的 virtualenv 中的 pip 执行此操作可确保它根据您正在运行的 python 版本创建正确的 mod_wsgi 版本。

【讨论】:

在这种情况下使用 pip install mod_wsgi 将无济于事,因为他们没有使用 mod_wsgi-express 使用 mod_wsgi 的方法。这是一种完全不同的部署 mod_wsgi 的方式,您不要混合使用它们。 啊,那我会更新以反映这一点。谢谢,我是一个经验不足的贡献者。 Graham,他们只需要指向 apache 配置中的新 .so 文件,对吗?我想确保我没有误导任何人。 严格来说,您并没有误导任何人。 mod_wsgi-express 脚本有一种方法可以告诉您模块在哪里,并将其复制到 Apache 安装中,但总的来说,当混合两种不同的方式时,我发现人们会感到困惑。如果想走这条路,我会补充您的答案并详细说明最佳方式。 感谢格雷厄姆增加了很多清晰度。【参考方案3】:

至少对于这个问题,我认为是我没有授予站点包文件夹及其内容足够的权限。这样做后我取得了一些进展,但现在遇到了我在另一个线程中打开的其他问题。

我为组 apache 递归地提供了 site-packages 文件夹 rwx。

这是我的问题的下一部分:

Issues getting Python 2.7 to work with my django project

【讨论】:

以上是关于让 Django 项目在 mod_wsgi 中运行时出现问题的主要内容,如果未能解决你的问题,请参考以下文章

如何仅在一个进程中使用 mod_wsgi 和 django 运行 Apache?

使用 mod_wsgi 在 Centos 6.5 上部署基于 python3.4 的 Django 项目:可行吗?

Apache 2 + mod_wsgi + WSGIScriptAlias

我可以让一些代码像守护进程一样在 Django 中不断运行吗

使用 apache2 在 mod_wsgi 上运行 django python 3.4

使用 mod_wsgi 和 django 运行 Apache