如何解决忽略服务总线队列触发功能应用程序功能的 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 引用的信息。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。