我安装了运行mod_wsgi的Apache2。我已经确认mod_wsgi实际上遵循this。
当我试图让Pyramid运行时问题出现了。我收到内部服务器错误,我的Apache错误日志包含异常:
AssertionError: The EvalException middleware is not usable in a multi-process environment
这是我的VHost:
<VirtualHost *:80>
ServerName pyramidtest.dev
DocumentRoot /srv/pyramidtest.dev/www/
AssignUserID pyramidtest nogroup
WSGIScriptAlias / /srv/pyramidtest.dev/pyramid/load.wsgi
</VirtualHost>
这是我的load.wsgi
:
import site
site.addsitedir('/opt/pyramid/lib/python2.7/site-packages')
from pyramid.paster import get_app
application = get_app('/srv/pyramidtest.dev/pyramid/test/development.ini', 'main')
mod_wsgi被编译为使用/opt/python2.7
作为Python解释器,但我在/opt/pyramid
的virtualenv下运行Pyramid - 这就是我在load.wsgi中有site.addsitedir()
的原因。
如果需要,apache2 -V
:
Server version: Apache/2.2.9 (Debian)
Server built: Dec 30 2010 11:50:24
Server's Module Magic Number: 20051115:15
Server loaded: APR 1.2.12, APR-Util 1.2.12
Compiled using: APR 1.2.12, APR-Util 1.2.12
Architecture: 32-bit
Server MPM: ITK
threaded: no
forked: yes (variable process count)
Server compiled with....
-D APACHE_MPM_DIR="server/mpm/experimental/itk"
-D APR_HAS_SENDFILE
-D APR_HAS_MMAP
-D APR_HAVE_IPV6 (IPv4-mapped addresses enabled)
-D APR_USE_SYSVSEM_SERIALIZE
-D APR_USE_PTHREAD_SERIALIZE
-D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
-D APR_HAS_OTHER_CHILD
-D AP_HAVE_RELIABLE_PIPED_LOGS
-D DYNAMIC_MODULE_LIMIT=128
-D HTTPD_ROOT=""
-D SUEXEC_BIN="/usr/lib/apache2/suexec"
-D DEFAULT_PIDLOG="/var/run/apache2.pid"
-D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
-D DEFAULT_LOCKFILE="/var/run/apache2/accept.lock"
-D DEFAULT_ERRORLOG="logs/error_log"
-D AP_TYPES_CONFIG_FILE="/etc/apache2/mime.types"
-D SERVER_CONFIG_FILE="/etc/apache2/apache2.conf"
我错过了什么......?
答案 0 :(得分:6)
您正在使用EvalException中间件(从错误消息中可以看出)。这个错误的解决方案实际上包含在mod_wsgi的Debugging Techniques wiki中。
基本上,由于中间件允许对应用程序进行基于浏览器的交互式调试,因此所有请求都需要发送到同一个进程;但是,您在嵌入模式下运行mod_wsgi,默认情况下可以创建许多进程。
来自维基:
[...]如果你想能够使用它 基于浏览器的交互式调试器,如果 在嵌入式中运行应用程序 mod_wsgi的模式,你需要 配置Apache只有它 启动一个子进程来处理 请求,它永远不会创建任何 额外的过程。阿帕奇 需要的配置指令 实现这一点如下。
StartServers 1 ServerLimit 1
切换到守护进程模式(使用单个进程,默认设置)也可以解决此问题,建议在嵌入模式下运行。以下是Apache指令:
WSGIDaemonProcess pyramidtest.dev display-name=%{GROUP}
WSGIProcessGroup pyramidtest.dev
mod_wsgi还可以为您添加Python路径的路径。如果使用嵌入模式,您可以使用:
WSGIPythonPath /opt/pyramid/lib/python2.7/site-packages
如果使用守护进程模式,请使用WSGIDaemonProcess指令的'python-path'选项。
WSGIDaemonProcess pyramidtest.dev display-name=%{GROUP} python-path=/opt/pyramid/lib/python2.7/site-packages
WSGIProcessGroup pyramidtest.dev