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

问题描述

为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 ********-queue external 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"

 

参考资料

 

posted @ 2025-07-07 21:15  编码者卢布  阅读(23)  评论(0)    收藏  举报