忽略服务总线队列触发功能应用程序功能的 host.json 设置

问题描述

当由队列触发的函数需要调用第 3 方 API 时,我试图锁定内部文档以获得最佳实践,而在此情况下可能需要考虑节流。我遵循了我能找到的所有文档,无论是 MS 官方文档、stackoverflow 文档还是来自适当的 github 存储库。

我已经使用 CLI 设置了 functionAppScaleLimit=1

 az resource update --resource-type Microsoft.Web/sites -g resourceGroupName -n functionAppName/config/web --set properties.functionAppScaleLimit=1

我在应用设置中手动将 WEBSITE_MAX_DYNAMIC_APPLICATION_SCALE_OUT 设置为 1。

我在 Azure 门户中验证,在横向扩展设置下,函数应用显示手动横向扩展和 1 个实例数。

我在 host.json 中有以下内容(我没有使用 Functionsstartup 属性

{
  "version": "2.0","logging": {
    "applicationInsights": {
      "samplingExcludedTypes": "Request","samplingSettings": {
        "isEnabled": true
      }
    },"extensions": {
      "serviceBus": {
        "prefetchCount": 1,"messageHandlerOptions": {
          "autoComplete": true,"maxConcurrentCalls": 1,"maxAutoRenewDuration": "00:05:00"
        },"sessionHandlerOptions": {
          "autoComplete": true,"messageWaitTimeout": "00:00:30","maxAutoRenewDuration": "00:55:00","maxConcurrentSessions": 1
        }
      }
    }
  }
}

我的服务总线队列启用了会话。消息在函数应用程序中成功处理(为测试并发性添加了人工延迟。但是,当我测试并向队列发送 100 条消息时(一次一个,未批量处理且我的函数未设置为接收批量消息),每个会话 10 条,我看到所有 10 个会话同时处理。我希望在任何给定时间看到来自一个会话处理的一条消息。

有什么建议吗?我是否遗漏了一些明显的东西?

附带说明一下,在函数执行期间,如果我不使用 Functionsstartup 执行,那么记录所有设置(包括函数实际使用的 host.json 中的设置)的最简单方法是什么?

解决方法

目前在您的 host.json 中定义的扩展部分结构位于 logging 部分下,这是不正确的。它应该在 logging 部分之外。

使用以下正确定义扩展部分的方法。

{
    "version": "2.0","logging": {
        "applicationInsights": {
            "samplingExcludedTypes": "Request","samplingSettings": {
                "isEnabled": true
            }
        }
    },"extensions": {
        "serviceBus": {
            "prefetchCount": 1,"messageHandlerOptions": {
                "autoComplete": true,"maxConcurrentCalls": 1,"maxAutoRenewDuration": "00:05:00"
            },"sessionHandlerOptions": {
                "autoComplete": true,"messageWaitTimeout": "00:00:30","maxAutoRenewDuration": "00:55:00","maxConcurrentSessions": 1
            }
        }
    }
}

请参阅 this 以了解有关 host.json 引用的信息。