Django + pipenv + Apache + mod_wsgi 在 ubuntu 上的部署未加载模块

Django + pipenv + Apache + mod_wsgi deployment on ubuntu not loading modules

我正在尝试使用 apache 和 mod_wsgi 在 Ubuntu 服务器上部署 django 项目。

我正在使用 python3 和 pipenv 来管理 venv。

环境变量PIPENV_VENV_IN_PROJECT=True 以便pipenv 创建的venv 位于项目文件夹内。

这是项目结构:

/srv/project
|
|-.venv # venv creted by pipenv
| |-bin
| |-...
|
|-Pipfile
|-Pipfile.lock
|
|-django_app
  |
  |-manage.py
  |-...
  |
  |-django_app
    |
    |-settings.py
    |-...
    |-wsgi.py

Apache 虚拟主机配置(/etc/apache2/sites-available/000-default.conf):

<VirtualHost *:80>
    <Directory /srv/project/django_app/django_app>
            <Files wsgi.py>
                    Require all granted
            </Files>
    </Directory>

    WSGIDaemonProcess django_app python-home=/srv/project/.venv python-path=/srv/project/django_app
    WSGIProcessGroup django_app
    WSGIScriptAlias / /srv/project/django_app/django_app/wsgi.py

    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined

</VirtualHost>

Apache 工作正常并正确响应,直到我添加配置的 WSGI 部分。然后它停止响应(所有请求都处于待处理状态)。

并且相同的错误消息在 apache 错误日志中不断重复 (/var/log/apache2/error.log) - 即使没有请求发送到服务器:

Current thread 0x00007f300f446bc0 (most recent call first):
[Tue Jan 29 15:43:58.899091 2019] [core:notice] [pid 16407:tid 139844391300032] AH00051: child pid 22818 exit signal Aborted (6), possible coredump in /etc/apache2
Fatal Python error: Py_Initialize: Unable to get the locale encoding
ModuleNotFoundError: No module named 'encodings'

似乎进程无法加载模块,可能是因为 venv 配置不当(不是真的使用 venv?)。但我尝试过的都无济于事。

我也将此代码添加到 wsgi.py,但它没有帮助:

python_home = '/srv/project/.venv'

activate_this = python_home + '/bin/activate_this.py'
exec(open(activate_this).read(), dict(__file__=activate_this))

想法?谢谢!

问题已解决。我已经执行了几个步骤,但我不确定其中哪一个是关键的:

  1. 我注意到 venv 中的 Python 版本 (3.7.2) 与系统中安装的 Python 版本 (3.6.2) 不同。所以我将 Pipfile 中所需的版本降级为 3.6.7 - 现在它与系统 python 版本相同。
  2. 通过删除文件夹 (.venv) 然后删除 .venv 运行 pipenv --rm
  3. 运行pipenv install 再次创建了 venv。当然,这个新创建的venv是降级的python版本
  4. 重新启动 apache... 瞧!

此外,wsgi.py中的添加是不必要的并且没有帮助解决问题:

python_home = '/srv/project/.venv'

activate_this = python_home + '/bin/activate_this.py'
exec(open(activate_this).read(), dict(__file__=activate_this))

希望这会对某人有所帮助。