Получение проблем с зависимостями при развертывании Python Flask Web API на портале Azure
Я пытаюсь развернуть веб-API Python flask на портале Azure, но у меня возникают проблемы с установкой зависимостей, как показано на рисунке ниже.
Я уже добавил расширение -Python 3.5.4 x64 в свое веб-приложение Azure, а также использую последнюю версию для всех зависимостей, как вы можете видеть в файле needs.txt.
Также я попробовал это - установить / обновить setuptools из Azure Kudu DebugConsole, но это приводит к проблеме отказа в доступе.
Kudu Remote Execution Console
Type 'exit' then hit 'enter' to get a new CMD process.
Type 'cls' to clear the console
Microsoft Windows [Version 10.0.14393]
(c) 2016 Microsoft Corporation. All rights reserved.
D:\home>pip install -U setuptools
'pip' is not recognized as an internal or external command,
operable program or batch file.
D:\home>python -m pip install -U setuptools
Downloading/unpacking setuptools from https://files.pythonhosted.org/packages/e7/16/da8cb8046149d50940c6110310983abb359bbb8cbc3539e6bef95c29428a/setuptools-40.6.2-py2.py3-none-any.whl#sha256=88ee6bcd5decec9bd902252e02e641851d785c6e5e75677d2744a9d13fed0b0a
Installing collected packages: setuptools
Found existing installation: setuptools 2.1
Uninstalling setuptools:
Cleaning up...
Exception:
Traceback (most recent call last):
File "D:\Python34\lib\site-packages\pip\basecommand.py", line 122, in main
status = self.run(options, args)
File "D:\Python34\lib\site-packages\pip\commands\install.py", line 283, in run
requirement_set.install(install_options, global_options, root=options.root_path)
File "D:\Python34\lib\site-packages\pip\req.py", line 1431, in install
requirement.uninstall(auto_confirm=True)
File "D:\Python34\lib\site-packages\pip\req.py", line 598, in uninstall
paths_to_remove.remove(auto_confirm)
File "D:\Python34\lib\site-packages\pip\req.py", line 1836, in remove
renames(path, new_path)
File "D:\Python34\lib\site-packages\pip\util.py", line 295, in renames
shutil.move(old, new)
File "D:\Python34\lib\shutil.py", line 535, in move
os.unlink(src)
PermissionError: [WinError 5] Access is denied: 'd:\\python34\\lib\\site-packages\\__pycache__\\easy_install.cpython-34.pyc'
Storing debug log for failure in D:\home\pip\pip.log
1 ответ
В веб-приложениях Azure у вас нет прав на выполнение какой-либо операции записи по пути D:\
Кроме D:\home
, Поэтому, когда вы хотите установить pip для среды исполнения Python по умолчанию, которая находится в D:\Python34
, это вызовет ошибку PermissionError Access is denied
,
Единственный способ - установить расширение сайта Python через Kudo и настроить web.config
использовать его вместо стандартного. Существует ответ существующего потока SO. Почему служба развертывания dzango службы приложений Azure продолжает давать сбой? который представляет установку, к которой вы можете обратиться, чтобы решить ее.
И теперь я вижу, что вы установили это расширение, но вызванная вами команда python по-прежнему используется по умолчанию. Решения, как показано ниже.
- Изменить переменную среды
path
через командуset PATH=D:\home\Python34;%PATH%
для покрытия по умолчанию. - Измените текущий каталог в Kudo DebugConsole и перейдите в путь
D:\home\Python34
, то вы можете напрямую позвонитьpython
который будет новым установленным.
Надеюсь, поможет.