最近,我使用具有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触发器。
是否缺少任何内容?还是需要使用其他图像?
答案 0 :(得分:4)
在Dockerfile中,添加ENV AzureFunctionsJobHost__Logging__Console__IsEnabled=true
以启用日志记录,设置为doc,所以我们现在必须手动进行操作。
如果获得401 Unauthorized,请找到文件function.json,如果将authLevel为anonymous
更改为function
(模板中的默认值)。除了anonymous
以外,我们无法在具有authlevel的本地容器中访问http触发器。因为我们还没有omitted in the basic image,所以在使用容器创建Function应用程序后即可使用。
关于为什么我们在容器外使用function
时可以使用func host start
认证级别访问http触发器的原因,在本地运行时,无论指定的认证级别如何,都将禁用授权。