Python на Win Nano Server контейнер DLL ошибки импорта
У меня есть веб-приложение Django, которое я хочу попробовать развернуть в контейнере Windows Nano Server Docker. Приложение зависит от пары двоичных файлов Windows (файлы.exe), поэтому я не могу на этом этапе перенести его на * nix. Это также зависит от библиотеки подушек.
Я создал Dockerfile, который начинается с изображения stefanscherer/python-windows:nano
, который выглядит как Nano Server с установленным Python 3.6.4. У меня есть сценарий PowerShell, который управляет настройкой venv, размещением файлов там, где они нужны, а также извлечением двоичных зависимостей Windows и размещением их в нужных местах.
Скрипт работает pip install -r requirements
который успешно устанавливает все перечисленные пакеты. Однако когда мой скрипт запускает команду python manage.py migrate
чтобы настроить локальную базу данных, я получаю ошибку импорта DLL в подушку:
Setting up database: python manage.py migrate
Traceback (most recent call last):
File "manage.py", line 15, in <module>
execute_from_command_line(sys.argv)
File "C:\vt\venv\lib\site-packages\django\core\management\__init__.py", line 381, in execute_from_command_line
utility.execute()
File "C:\vt\venv\lib\site-packages\django\core\management\__init__.py", line 375, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "C:\vt\venv\lib\site-packages\django\core\management\base.py", line 316, in run_from_argv
self.execute(*args, **cmd_options)
File "C:\vt\venv\lib\site-packages\django\core\management\base.py", line 350, in execute
self.check()
File "C:\vt\venv\lib\site-packages\django\core\management\base.py", line 379, in check
include_deployment_checks=include_deployment_checks,
File "C:\vt\venv\lib\site-packages\django\core\management\commands\migrate.py", line 60, in _run_checks
issues.extend(super()._run_checks(**kwargs))
File "C:\vt\venv\lib\site-packages\django\core\management\base.py", line 366, in _run_checks
return checks.run_checks(**kwargs)
File "C:\vt\venv\lib\site-packages\django\core\checks\registry.py", line 71, in run_checks
new_errors = check(app_configs=app_configs)
File "C:\vt\venv\lib\site-packages\django\core\checks\urls.py", line 13, in check_url_config
return check_resolver(resolver)
File "C:\vt\venv\lib\site-packages\django\core\checks\urls.py", line 23, in check_resolver
return check_method()
File "C:\vt\venv\lib\site-packages\django\urls\resolvers.py", line 396, in check
for pattern in self.url_patterns:
File "C:\vt\venv\lib\site-packages\django\utils\functional.py", line 37, in __get__
res = instance.__dict__[self.name] = self.func(instance)
File "C:\vt\venv\lib\site-packages\django\urls\resolvers.py", line 533, in url_patterns
patterns = getattr(self.urlconf_module, "urlpatterns", self.urlconf_module)
File "C:\vt\venv\lib\site-packages\django\utils\functional.py", line 37, in __get__
res = instance.__dict__[self.name] = self.func(instance)
File "C:\vt\venv\lib\site-packages\django\urls\resolvers.py", line 526, in urlconf_module
return import_module(self.urlconf_name)
File "C:\Python\lib\importlib\__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 994, in _gcd_import
File "<frozen importlib._bootstrap>", line 971, in _find_and_load
File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
File "C:\vt\smartclass\smartclass\urls.py", line 13, in <module>
path('', include('faq_video_portal.urls')),
File "C:\vt\venv\lib\site-packages\django\urls\conf.py", line 34, in include
urlconf_module = import_module(urlconf_module)
File "C:\Python\lib\importlib\__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 994, in _gcd_import
File "<frozen importlib._bootstrap>", line 971, in _find_and_load
File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
File "C:\vt\smartclass\faq_video_portal\urls.py", line 3, in <module>
from .views.course_views import *
File "C:\vt\smartclass\faq_video_portal\views\course_views.py", line 6, in <module>
from PIL import Image
File "C:\vt\venv\lib\site-packages\PIL\Image.py", line 64, in <module>
from . import _imaging as core
ImportError: DLL load failed: The specified procedure could not be found.
Я искал всю информацию по этой проблеме, и большинство сообщений указывают на проблемы с Pillow 4.0 и Python 3.6.0. В моем файле требований не указана версия, поэтому он использует Pillow 5.3.0. В нескольких публикациях просто указывалось "обновить до Python 3.6.1 или более поздней версии, так как она устраняет проблему импорта DLL, и / или попробовать Pillow 4.1.1 или более позднюю версию". Но я на 3.6.4. Я уверен, что проблема как-то специфична для Nano Server.
Глядя еще дальше, я понял, что .pyd
Файл для Pillow зависит от библиотек среды выполнения Visual C++ 2015, которые не включены в Nano Server. Nano Server также не имеет установщика, поэтому я не мог просто добавить установщик среды выполнения VC++ в команды моего Dockerfile. На странице Microsoft предлагается просто скопировать необходимое .dll
двоичные файлы в образ Nano Server, и он должен работать, поэтому я скопировал все api-ms-crt-...dll
файлы по тому же пути в образе Nano Server. Однако сбой импорта DLL все еще происходит.
В крайнем случае я попытался перейти на полный образ Python на Server Core (python:3-msservercore
). Это не удалось, потому что когда pip установил Pillow, он, очевидно, решил, что ему нужно скомпилировать себя, и, конечно, в контейнере нет среды компилятора C.
Как я могу дополнительно диагностировать и устранить ошибку импорта, которая происходит в Nano Server?