【Azure Container App】配置容器应用的缩放规则 Managed Identity 连接中国区 Azure Service Bus 问题

简介: 本文介绍了在 Azure Container Apps 中配置基于自定义 Azure Service Bus 的自动缩放规则时,因未指定云环境导致的域名解析错误问题。解决方案是在扩展规则中添加 `cloud=AzureChinaCloud` 参数,以适配中国区 Azure 环境。内容涵盖问题描述、原因分析、解决方法及配置示例,适用于使用 KEDA 实现事件驱动自动缩放的场景。

问题描述

为Azure Container App配置自动缩放规则,使用自定义 Azure Service Bus作为缩放规则的数据源。当消息总数每增长100,就增加一个Replica。相反,则减少一个Replica。

而中国区的Container App在配置使用管理标识(Managed Identity)进行认证时候,会出现如下错误:

ERROR:invalid metrics (1 invalid out of 5), first error is: failed to get ********-queue external metric value: failed to get********-queueexternal metric

unable to fetch metrics from external metrics api: rpc error: code = unknown desc = error

dial tcp: lookup ********-queue.servicebus.windows.net on xxxxxxxx : no such host"

 

问题解答

根据错误信息,它的原因就是配置Managed Identity时候没有指定Azure 环境,所以默认把Service Bus资源连接到Global Azure,所以报错无法解析域名:lookup ********-queue.servicebus.windows.net on xxxxxxxx : no such host 。

 

为解决此问题,需在 Azure Container Apps 的扩展规则中添加 cloud 参数,指定为 AzureChinaCloud

这是 KEDA(Kubernetes-based Event Driven Autoscaling)在中国 Azure 环境下的必要配置。

 

只需要在配置中添加 "cloud=AzureChinaCloud" 就可解决问题。

 

完成的配置命令如下:

# 使用used identity 
  az containerapp create --resource-group <resource group name> --name <container app name> --environment <container app environment name> 
--user-assigned 'user managed identity resource id'
--scale-rule-name azure-servicebus-test1 
--scale-rule-type azure-servicebus 
--scale-rule-metadata "namespace=sb-store-demo-12622" "queueName=orders" "messageCount=100" "cloud=AzureChinaCloud" "endpointSuffix=servicebus.chinacloudapi.cn"
--scale-rule-identity 'user managed identity resource id' 
  
  # 使用连接字符串 connection string
  az containerapp create --resource-group <resource group name> --name <container app name> --environment <container app environment name>  
--scale-rule-name azure-servicebus-test1   
--scale-rule-type azure-servicebus 
--scale-rule-metadata "namespace=sb-store-demo-12622" "queueName=orders" "messageCount=100"
--secrets "service bus connection string value"
--scale-rule-auth "connection=connection-string-secret"

 

参考资料

在 Azure 容器应用中设置缩放规则:https://docs.azure.cn/zh-cn/container-apps/scale-app?pivots=azure-cli#custom

KEDA Azure Service Bus: https://keda.sh/docs/2.17/scalers/azure-service-bus/

 

 





当在复杂的环境中面临问题,格物之道需:浊而静之徐清,安以动之徐生。 云中,恰是如此!

相关文章
|
人工智能 JSON 小程序
【一步步开发AI运动APP】七、自定义姿态动作识别检测——之规则配置检测
本文介绍了如何通过【一步步开发AI运动APP】系列博文,利用自定义姿态识别检测技术开发高性能的AI运动应用。核心内容包括:1) 自定义姿态识别检测,满足人像入镜、动作开始/停止等需求;2) Pose-Calc引擎详解,支持角度匹配、逻辑运算等多种人体分析规则;3) 姿态检测规则编写与执行方法;4) 完整示例展示左右手平举姿态检测。通过这些技术,开发者可轻松实现定制化运动分析功能。
|
8月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
545 16
|
8月前
|
数据建模 应用服务中间件 PHP
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
本示例演示如何通过Docker挂载同一宿主目录至Nginx与PHP容器,实现PHP项目运行环境配置。需注意PHP容器中监听地址修改为0.0.0.0:9000,并调整Nginx配置中fastcgi_pass指向正确的IP与端口。同时确保Nginx容器中/var/www/html权限正确,以避免访问问题。
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
|
10月前
《仿盒马》app开发技术分享-- 首页活动配置(5)
上一篇文章中我们实现了项目端云一体化首页部分模块动态配置,实现了对模块模块的后端控制显示和隐藏,这能让我们的app更加的灵活,也能应对更多的情况。现在我们来对配置模块进行完善,除了已有的模块以外,我们还有一些banner ,活动入口等模块,这些模块的数据并不多,所以我们也归纳到配置中去实现。并且我们在配置表中添加了一些不同的id,我们只需要根据相对应的id 去查询对应的表就可以了
171 0
|
8月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
1202 108
|
9月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
704 57