host.json Service Bus Queue Triggered Function App Function 忽略的设置

host.json Settings Ignored For Service Bus Queue Triggered Function App Function

当队列触发的函数需要调用第 3 方 API 时,我试图锁定内部文档以获取最佳实践,其中节流可能是一个问题。我遵循了我能找到的所有文档,无论是 MS 官方文件、Whosebug 还是来自适当的 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 参考资料。