Azure Function Docker无法与http触发器一起使用

时间:2018-11-21 12:41:06

标签: azure docker azure-functions

最近,我使用具有HttpTrigger的Azure Function(节点)创建了一个docker映像。这是默认情况下生成的基本HttpTrigger。我正在Macbook Pro(MoJave)上进行开发,并且安装了以下工具。

NodeJ-节点/10.13.0 适用于macOS的.NET Core 2.1 Azure Function核心工具(通过brew)

当我使用“ func host start”在本地运行该函数时,一切正常,我可以看到该函数正在加载消息。我还可以使用触发器端点执行Azure函数。但是,当我尝试构建Docker容器并运行该容器时,我可以加载应用程序的主页,但无法到达函数端点。在日志中,我只能看到以下内容;

Hosting environment: Production
Content root path: /
Now listening on: http://[::]:80
Application started. Press Ctrl+C to shut down.

我的Docker文件如下(由Azure核心工具生成);

FROM mcr.microsoft.com/azure-functions/node:2.0
ENV AzureWebJobsScriptRoot=/home/site/wwwroot
COPY . /home/site/wwwroot

当我尝试使用“ microsoft / azure-functions-runtime:v2.0.0-beta1”作为基本映像时,可以看到该函数正在加载并且还可以访问http触发器。

是否缺少任何内容?还是需要使用其他图像?

1 个答案:

答案 0 :(得分:4)

  1. 在Dockerfile中,添加ENV AzureFunctionsJobHost__Logging__Console__IsEnabled=true以启用日志记录,设置为doc,所以我们现在必须手动进行操作。

  2. 如果获得401 Unauthorized,请找到文件function.json,如果将authLevel为anonymous更改为function(模板中的默认值)。除了anonymous以外,我们无法在具有authlevel的本地容器中访问http触发器。因为我们还没有omitted in the basic image,所以在使用容器创建Function应用程序后即可使用。

    关于为什么我们在容器外使用function时可以使用func host start认证级别访问http触发器的原因,在本地运行时,无论指定的认证级别如何,都将禁用授权。