Python Azure WebJob 导入错误 - 无法导入 Python 扩展模块

Python Azure WebJob Import Error - Cannot import Python Extension Modules

我正在尝试使用 Azure WebJob 运行 一个 Python 脚本,当我想要发出请求并生成 CSV 时它工作正常。我已经成功压缩了我需要的所有包和我的脚本,并将它们上传到 Azure App_Data 目录。

但是,我还需要能够连接到 SFTP 站点,并且一些所需的包包含 Python 扩展模块。当我在本地 运行 脚本时。它工作正常。但是,当我 运行 在 Azure 上时,我收到一条消息说 "ImportError: cannot import name _bcrypt"

这是我的脚本:

import sys, os
sys.path.append(os.path.join(os.getcwd(), "site-packages"))

import pysftp
import paramiko

hostname = 'host'
username='user'
password='pass'
port='port'

source = 'D:\Home\PunchData.csv'
destination = 'PunchData_Success.csv'

client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
client.connect(hostname=hostname,port=port,username=username,password=password)

ftp_client=client.open_sftp()

ftp_client.chdir('uploads')

ftp_client.put(source,destination)

ftp_client.close()

这是我收到的完整错误消息:

[12/15/2018 00:36:26 > 00ceeb: SYS INFO] Status changed to Initializing
[12/15/2018 00:36:28 > 00ceeb: SYS INFO] Job directory change detected: Job file 'enum\LICENSE' exists in source directory but not in working directory.
[12/15/2018 00:37:03 > 00ceeb: SYS INFO] Run script 'run.py' with script host - 'PythonScriptHost'
[12/15/2018 00:37:03 > 00ceeb: SYS INFO] Status changed to Running
[12/15/2018 00:37:06 > 00ceeb: ERR ] Traceback (most recent call last):
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "run.py", line 1, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     import pysftp
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "D:\local\Temp\jobs\triggered\FTPTestzbuguvp.pts\pysftp\__init__.py", line 12, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     import paramiko
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "D:\local\Temp\jobs\triggered\FTPTestzbuguvp.pts\paramiko\__init__.py", line 22, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     from paramiko.transport import SecurityOptions, Transport
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "D:\local\Temp\jobs\triggered\FTPTestzbuguvp.pts\paramiko\transport.py", line 90, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     from paramiko.ed25519key import Ed25519Key
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "D:\local\Temp\jobs\triggered\FTPTestzbuguvp.pts\paramiko\ed25519key.py", line 17, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     import bcrypt
[12/15/2018 00:37:06 > 00ceeb: ERR ]   File "D:\local\Temp\jobs\triggered\FTPTestzbuguvp.pts\bcrypt\__init__.py", line 25, in <module>
[12/15/2018 00:37:06 > 00ceeb: ERR ]     from . import _bcrypt
[12/15/2018 00:37:06 > 00ceeb: ERR ] ImportError: cannot import name _bcrypt
[12/15/2018 00:37:06 > 00ceeb: SYS INFO] Status changed to Failed
[12/15/2018 00:37:06 > 00ceeb: SYS ERR ] Job failed due to exit code 1

每次导入 Python 扩展模块似乎都会失败。我在 Windows 机器上使用 32 位 Python 2.7 环境。我读过,对于 Azure 函数,您需要使用 Python 轮子来替换 Python 扩展模块,但我不确定如何将轮子用于 Azure WebJob。将滚轮上传到 WebJob 目录并不能解决问题。

如有任何帮助,我们将不胜感激!

我想出了解决办法。

不是直接使用 Python 脚本将 zip 文件中的 Python 包上传到 WebJob,而是可以在 WebApp 中使用 pip 安装包。为此,我首先在应用程序设置中添加了一个处理程序映射来指定我的 Python 版本:

然后我打开了Kudu console

打开 Kudu 控制台后,我转到站点扩展并确保安装了我想要的 Python 版本:

然后我转到“调试控制台”>“CMD”打开命令提示符,并使用 pip 安装了我需要的所有包:

安装完所有必需的包后,我就可以将它们从 WebJob 目录中删除。 WebJob 脚本能够使用刚刚使用 pip 安装的包。一旦我 运行 它,我就不再对 Azure 能够导入 Python 扩展模块有任何问题。

希望这对遇到类似问题的人有所帮助。