首页 文章

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

提问于
浏览
2

我想在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时将看不到“它已走过”页面 . 所以我把服务器的外部IP . 然后它走得很好 .

查看Apache 2错误日志 .

[Wed May 02 21:32:28.100569 2018] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:编译为Python / 3.5.1 .

[Wed May 02 21:32:28.100633 2018] [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 - 恢复正常操作

[Wed May 02 21:32:28.101426 2018] [核心:通知] [pid 22648:tid 140282945054592] AH00094:命令行:'/ usr / sbin / apache2'

[Wed May 02 21:32:28.191175 2018] [wsgi:error] [pid 22651:tid 140282945054592] mod_wsgi(pid = 22651):调用'site.addsitedir()'为'(null)'失败,停止 .

[Wed May 02 21:32:28.192041 2018] [wsgi:error] [pid 22651:tid 140282945054592] mod_wsgi(pid = 22651):调用'site.addsitedir()'为'/ home / ubuntu / Django / myvenv失败/lib/python3.5/site-packages' .

[Wed May 02 21:33:21.733277 2018] [mpm_event:notice] [pid 22648:tid 140282945054592] AH00494:收到SIGHUP . 试图重新启动

[Wed May 02 21:33:21.787095 2018] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:编译为Python / 3.5.1 .

[Wed May 02 21:33:21.787410 2018] [wsgi:warn] [pid 22648:tid 140282945054592] mod_wsgi:使用Python / 3.5.2运行时 .

[Wed May 02 21:33:21.788397 2018] [mpm_event:notice] [pid 22648:tid 140282945054592] AH00489:Apache / 2.4.18(Ubuntu)mod_wsgi / 4.3.0配置Python / 3.5.2 - 恢复正常操作

[Wed May 02 21:33:21.788447 2018] [core:notice] [pid 22648:tid 140282945054592] AH00094:命令行:'/ usr / sbin / apache2'

[Wed May 02 21:33:21.860854 2018] [wsgi:error] [pid 22781:tid 140282945054592] mod_wsgi(pid = 22781):调用'site.addsitedir()'为'(null)'失败,停止 .

[Wed May 02 21:33:21.860889 2018] [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)',停止 . 错误日志仍然出现 .

我该如何解决这个错误?

1 回答

  • 1

    不要使用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 后它没有't show latest mod_wsgi, it is because you didn' t禁用/卸载系统mod_wsgi包 . 您需要手动配置Apache以加载较新的mod_wsgi,方法是运行 mod_wsgi-express module-config 并获取输出并将其添加到Apache配置中 .

相关问题