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

标签 python azure azure-webjobs

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

AzureWebJobDirectory

但是,我还需要能够连接到 SFTP 站点,并且所需的一些包包含 Python 扩展模块。当我在本地运行脚本时。效果很好。但是,当我在 Azure 上运行时,我收到一条消息“ImportError:无法导入名称 _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\FTPTest\5zbuguvp.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\FTPTest\5zbuguvp.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\FTPTest\5zbuguvp.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\FTPTest\5zbuguvp.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\FTPTest\5zbuguvp.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 目录并不能解决问题。

任何帮助将不胜感激!

最佳答案

我找到了解决办法。

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

Handler Mapping

然后我打开了Kudu console

Kudu

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

KuduSiteExtensions

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

Kudupipinstall

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

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

关于Python Azure WebJob 导入错误 - 无法导入 Python 扩展模块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53850537/

相关文章:

c# - Azure 无法将消息添加到队列

Python偏导数容易

Python 诅咒取消设置 'onlcr' 并破坏我的终端;如何*正确*重置

azure - 回滚部署/发布?

azure - 向 Azure Open AI 发出 API 请求时不支持的数据类型

azure - 如何访问 Azure 订阅上的死信子队列?

c# - 有没有办法使 Azure WebJobs ServiceBus 输出参数可选?

python - 具有一些重复的非素数因式分解

javascript - Selenium WebDriver Python重新加载html而不刷新页面

Azure Web 作业 - 授权基本 header