首页 > 解决方案 > 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)',停止。错误日志仍然出现。

如何解决此错误?

标签: pythondjangoapacheamazon-web-serviceswsgi

解决方案


不要使用 mod_wsgi 4.3.0。它很旧,并且在向python-path. 或者使用:

WSGIDaemonProcess bot python-home=/home/ubuntu/Django/myvenv python-path=/home/ubuntu/Django/bot

你不应该使用site-packageswith python-path。这不是推荐的方式,并且自 mod_wsgi 3.3 以来一直没有。

有关使用虚拟环境的更多详细信息,请参阅:

如果使用后pip install mod_wsgi没有显示最新的 mod_wsgi,那是因为你没有禁用/卸载系统 mod_wsgi 包。您还需要手动配置 Apache 以加载较新的 mod_wsgi,方法是运行mod_wsgi-express module-config并获取输出并将其添加到 Apache 配置中。


推荐阅读