致命的 Python 错误:init_fs_encoding:尝试启动 uwsgi 时,无法获取文件系统编码的 Python 编解码器

Den*_*nys 11 python django ubuntu uwsgi

我试图在我的虚拟环境中启动我的 uwsgi 服务器,但是在我添加plugin python3选项后,我每次都会收到此错误:

!!! Python Home is not a directory: /home/env3/educ !!!
Set PythonHome to /home/env3/educ
Python path configuration:
  PYTHONHOME = '/home/env3/educ'
  PYTHONPATH = (not set)
  program name = '/home/env3/educ/bin/python'
  isolated = 0
  environment = 1
  user site = 1
  import site = 1
  sys._base_executable = '/home/env3/educ/bin/python'
  sys.base_prefix = '/home/env3/educ'
  sys.base_exec_prefix = '/home/env3/educ'
  sys.executable = '/home/env3/educ/bin/python'
  sys.prefix = '/home/env3/educ'
  sys.exec_prefix = '/home/env3/educ'
  sys.path = [
    '/home/env3/educ/lib/python38.zip',
    '/home/env3/educ/lib/python3.8',
    '/home/env3/educ/lib/python3.8/lib-dynload',
  ]
Fatal Python error: init_fs_encoding: failed to get the Python codec of the filesystem encoding
Python runtime state: core initialized
ModuleNotFoundError: No module named 'encodings'

Current thread 0x00007efe89db8780 (most recent call first):
<no Python frame>

Run Code Online (Sandbox Code Playgroud)

此外,我尝试使用创建新的虚拟环境python3 -m venv env并将项目文件移动到其中,但仍然出现相同的错误。这是我的 uwsgi.ini 文件:

[uwsgi]

base = /home/env3/educ
projectname = educ

plugins = python3
master = true
virtualenv = /home/env3/%(projectname)
pythonpath = %(base)
env = DJANGO_SETTINGS_MODULE=%(projectname).settings.pro
module = %(projectname).wsgi:application
socket = /tmp/%(projectname).sock
chmod-socket = 666
Run Code Online (Sandbox Code Playgroud)

我使用 Python 3.8.5

我正在尝试使用 Django + uWSGI + nginx + Postgresql

如果您需要更多详细信息,我会给它

谢谢

Alk*_*ian 13

我通过取消设置 PYTHONHOME 或 PYTHONPATH 来解决这个问题,因为它们会覆盖虚拟环境变量。

就我而言,这是由我的管理员的基本环境引起的。我会尝试通过以下方式删除 PYTHONHOME 和 PYTHONPATH 变量

unset PYTHONPATH
unset PYTHONHOME
Run Code Online (Sandbox Code Playgroud)


Chr*_* J. 11

我在浏览 Bing 而不是 Google 时找到了解决方案。

我看到你的 PYTHONHOME 设置为PYTHONHOME = '/home/env3/educ'. 尝试检查它是否真的存在。

的解决方案删除PYTHONHOME环境变量。对您来说,可以是这样,或者将该变量设置为另一个值。这适用于 Windows,并且肯定适用于 Linux。如果有人尝试此操作,请在此处发表评论!

一位 CPython 开发人员在这里确认了解决方案

这不是 Python 错误,这是在不需要 PYTHONHOME 和/或 PYTHONPATH 时设置它们的症状。在几乎所有情况下,您都不需要设置它们中的任何一个

在 PYTHONHOME 的情况下,设置.

  • 我遇到了同样的问题,但对我来说,家和路径还没有设置。有任何想法吗? (3认同)

小智 7

此消息适用于那些遇到相同问题的人,他们稍后会找到此页面。我无法使用我的配置启动 uWSGI,并且在日志文件中也有相同的消息。

init_fs_encoding:无法获取文件系统编码的 Python 编解码器 Python 运行时状态:核心已初始化 ModuleNotFoundError:没有名为“encodings”的模块

问题是 uWSGI 没有足够的权限来访问虚拟环境。当我修复权限时,uWSGI 开始了我的配置。

Denys 在他的消息中发布了 uwsgi.ini 配置。估计是虚拟环境的路径不对。

base = /home/env3/educ
projectname = educ
virtualenv = /home/env3/%(projectname)
Run Code Online (Sandbox Code Playgroud)

如果虚拟环境是在项目目录中创建的,那么路径应该如下所示:

virtualenv = /home/env3/%(projectname)/env
Run Code Online (Sandbox Code Playgroud)