Django, размещенный на Apache: Фатальная ошибка Python: init_fs_encoding: не удалось получить кодек Python файловой системы, кодирующей состояние выполнения Python:

#python #django #apache

Вопрос:

Я пытаюсь разместить приложение Django на Apache 2.4. Служба не запускается и выдает следующую ошибку

 [Thu Oct 28 13:12:37.898096 2021] [mpm_winnt:notice] [pid 5144:tid 628] AH00418: Parent: Created child process 7828
Python path configuration:
  PYTHONHOME = (not set)
  PYTHONPATH = (not set)
  program name = 'python'
  isolated = 0
  environment = 1
  user site = 1
  import site = 1
  sys._base_executable = 'C:\apache24\bin\httpd.exe'
  sys.base_prefix = 'C:\Users\myuser\AppData\Local\Programs\Python\Python310'
  sys.base_exec_prefix = 'C:\Users\myuser\AppData\Local\Programs\Python\Python310'
  sys.platlibdir = 'lib'
  sys.executable = 'C:\apache24\bin\httpd.exe'
  sys.prefix = 'C:\Users\myuser\AppData\Local\Programs\Python\Python310'
  sys.exec_prefix = 'C:\Users\myuser\AppData\Local\Programs\Python\Python310'
  sys.path = [
    'C:\Users\myuser\AppData\Local\Programs\Python\Python310\python310.zip',
    '.\DLLs',
    '.\lib',
    'C:\apache24\bin',
  ]
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 0x00000fa0 (most recent call first):
  <no Python frame>
[Thu Oct 28 13:12:38.413708 2021] [mpm_winnt:crit] [pid 5144:tid 628] AH00419: master_main: create child process failed. Exiting.
 

Сервер запустился до того, как я выполнил все настройки и перешел к экрану «это сработало».

Я думаю, что это связано либо с моим httpd-host conf

 <Directory /some/path/project>
    Require all granted
</Directory>
<VirtualHost *:80>
    ServerName localhost 
    WSGIPassAuthorization On
    ErrorLog "C:/Users/myuser/Desktop/app.error.log"
    CustomLog "C:/Users/myuser/Desktop/app.access.log"  combined
    WSGIScriptAlias /  "C:/Users/myuser/Desktop/app/wsgi_windows.py"
    <Directory "C:/Users/myuser/Desktop/app/EmployeeKiosk">
        <Files wsgi_windows.py>
            Require all granted
        </Files>
    </Directory>

    Alias /static "C:/Users/myuser/Desktop/app/static"
    <Directory "C:/Users/myuser/Desktop/app/static">
        Require all granted
    </Directory>  
</VirtualHost>
 

или
Мой wsgi_windows py

 import os
import sys
import site

# Add the site-packages of the chosen virtualenv to work with
site.addsitedir('C:/Users/myuser/Desktop/app/appEnv/Lib/site-packages')




# Add the app's directory to the PYTHONPATH
sys.path.append('C:/Users/myuser/Desktop/app')
sys.path.append('C:/Users/myuser/Desktop/app/appEnv')

os.environ['DJANGO_SETTINGS_MODULE'] = 'app.settings'
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "app.settings")

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
 

Я использую виртуальную среду, и не так много четких инструкций о том, как с этим справиться.

Редактировать: я должен упомянуть, что это система Windows. согласно https://code.google.com/archive/p/modwsgi/wikis/ConfigurationDirectives.wiki#WSGIPythonHome Вы не можете использовать WSGIPythonHome для переопределения пути PYTHONEXECUTABLE. Но значение по умолчанию должно быть правильным, поскольку оно соответствует спискам ошибок.

Ответ №1:

Хорошо, с Windows вам не нужно использовать WSGIPythonHome. Apache игнорирует это. Что мне нужно было сделать, так это добавить и переменную среды PYTHONHOME и указать на глобальный каталог python — см. Ниже:

введите описание изображения здесь

Я перезагрузил apache, и он работал без проблем.