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 参考资料。
当队列触发的函数需要调用第 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 参考资料。