python - apache2 错误日志。对 '(null)' 调用 'site.addsitedir()' 失败,停止
问题描述
我想在 Ubuntu 中连接 Python 和 Apache 2 服务器。
所以aws必须在ubuntu服务器中输入以下代码。
pip install Django
sudo apt-get install appache2
sudo apt-get install libapache2-mod-wsgi-py3
然后我创建了 Python 项目和 app 文件夹作为 Python venv。
Apache 2 000-default.conf 的代码如下所示:
<virtualhost *:80>
WSGIDaemonProcess bot python-path=/home/ubuntu/Django/bot:/home/ubuntu/Django/myvenv/lib/python3.5/site-packages
ServerAdmin webmaster@localhost
WSGIScriptAlias /52.78.108.223 /home/ubuntu/Django/bot/wsgi.py
<Directory /home/ubuntu/Django/bot>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</virtualhost>
位置是正确的。没有打字失误。
'WSGIScriptAlias '的第一个参数应该是空白的,但是如果你把它放在一个空白处,当你点击那个IP时你将看不到'it walk'页面。所以我把服务器的外部IP。然后它走得很好。
查看 Apache 2 错误日志。
[2018 年 5 月 2 日星期三 21:32:28.100569] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:为 Python/3.5.1+ 编译。
[2018 年 5 月 2 日星期三 21:32:28.100633] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:使用 Python/3.5.2 的运行时。
[Wed May 02 21:32:28.101406 2018] [mpm_event:notice] [pid 22648:tid 140282945054592] AH00489: Apache/2.4.18 (Ubuntu) mod_wsgi/4.3.0 Python/3.5.2 已配置——恢复正常操作
[2018 年 5 月 2 日星期三 21:32:28.101426] [core:notice] [pid 22648:tid 140282945054592] AH00094:命令行:'/usr/sbin/apache2'
[2018 年 5 月 2 日星期三 21:32:28.191175] [wsgi:error] [pid 22651:tid 140282945054592] mod_wsgi (pid=22651): 对 '(null)' 的调用 'site.addsitedir()' 失败,停止。
[2018 年 5 月 2 日星期三 21:32:28.192041] [wsgi:error] [pid 22651:tid 140282945054592] mod_wsgi (pid=22651): 对 '/home/ubuntu/Django/myvenv 的调用'site.addsitedir()' 失败/lib/python3.5/site-packages'。
[2018 年 5 月 2 日星期三 21:33:21.733277] [mpm_event:notice] [pid 22648:tid 140282945054592] AH00494:收到 SIGHUP。尝试重新启动
[2018 年 5 月 2 日星期三 21:33:21.787095] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:为 Python/3.5.1+ 编译。
[2018 年 5 月 2 日星期三 21:33:21.787410] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:使用 Python/3.5.2 的运行时。
[2018 年 5 月 2 日星期三 21:33:21.788397] [mpm_event:notice] [pid 22648:tid 140282945054592] AH00489: Apache/2.4.18 (Ubuntu) mod_wsgi/4.3.0 Python/3.5.2 已配置——恢复正常操作
[2018 年 5 月 2 日星期三 21:33:21.788447] [core:notice] [pid 22648:tid 140282945054592] AH00094:命令行:'/usr/sbin/apache2'
[2018 年 5 月 2 日星期三 21:33:21.860854] [wsgi:error] [pid 22781:tid 140282945054592] mod_wsgi (pid=22781): 对 '(null)' 调用 'site.addsitedir()' 失败,停止。
[2018 年 5 月 2 日星期三 21:33:21.860889] [wsgi:error] [pid 22781:tid 140282945054592] mod_wsgi (pid=22781): 对 '/home/ubuntu/Django/myvenv 的调用'site.addsitedir()' 失败/lib/python3.5/site-packages'。
它是这样出来的。
我搜索了互联网。据说wsgi版本低。
但是,apache2 使用的 wsgi 只能通过 'sudo apt-get install libapache2-mod-wsgi-py3' 安装。
Apache 2 错误日志显示 wsgi 版本为 4.3.0。
如果您使用“pip install mod-wsgi”安装最新版本的 wsgi,Apache 2 错误日志将显示 4.3.0。
'调用'site.addsitedir()'失败'(null)',停止。错误日志仍然出现。
如何解决此错误?
解决方案
不要使用 mod_wsgi 4.3.0。它很旧,并且在向python-path
. 或者使用:
WSGIDaemonProcess bot python-home=/home/ubuntu/Django/myvenv python-path=/home/ubuntu/Django/bot
你不应该使用site-packages
with python-path
。这不是推荐的方式,并且自 mod_wsgi 3.3 以来一直没有。
有关使用虚拟环境的更多详细信息,请参阅:
如果使用后pip install mod_wsgi
没有显示最新的 mod_wsgi,那是因为你没有禁用/卸载系统 mod_wsgi 包。您还需要手动配置 Apache 以加载较新的 mod_wsgi,方法是运行mod_wsgi-express module-config
并获取输出并将其添加到 Apache 配置中。