gpt4 book ai didi

python - apache2 错误日志。 'site.addsitedir()' 调用 '(null)' 失败,停止

转载 作者:太空宇宙 更新时间:2023-11-04 02:26:52 24 4
gpt4 key购买 nike

我想在 Ubuntu 中连接 Python 和 Apache 2 服务器。

所以aws要在ubuntu server中输入如下代码

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 walked'页面的。所以我把服务器的外部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 的运行时。

[2018 年 5 月 2 日星期三 21:32:28.101406] [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] [核心:通知] [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): 调用 'site.addsitedir()' 因 '(null)' 失败,停止。

[2018 年 5 月 2 日星期三 21:32:28.192041] [wsgi:error] [pid 22651:tid 140282945054592] mod_wsgi (pid=22651): 调用 'site.addsitedir()' 失败 '/home/ubuntu/Django/myvenv/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] [核心:通知] [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): 调用 'site.addsitedir()' 因 '(null)' 失败,停止。

[2018 年 5 月 2 日星期三 21:33:21.860889] [wsgi:error] [pid 22781:tid 140282945054592] mod_wsgi (pid=22781): 调用 'site.addsitedir()' 失败 '/home/ubuntu/Django/myvenv/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-packagespython-path 一起使用。这不是推荐的方式,自 mod_wsgi 3.3 以来也不是。

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

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

关于python - apache2 错误日志。 'site.addsitedir()' 调用 '(null)' 失败,停止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50165201/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com