使用 Bicep 以编程方式获取服务总线 SharedAccessKey

Get the Service Bus SharedAccessKey Programatically Using Bicep

我正在使用 bicep 创建 azure 资源。这些资源之一是服务总线,其定义如下:

resource service_bus 'Microsoft.ServiceBus/namespaces@2021-01-01-preview' = {
  name: '${service_bus_name}${uniqueString(service_bus_name)}'
  location: resourceGroup().location
  sku: {
    name: 'Standard'
    tier: 'Standard'
  }
  properties: {}
}

然后我想在另一个资源中使用这个服务总线,这就是我目前拥有的连接字符串:

name: 'AzureWebJobsServiceBus'
value: 'Endpoint=sb://${service_bus.name}.servicebus.windows.net/;SharedAccessKeyName=RootManageSharedAccessKey;SharedAccessKey=<hardcoded_key>'          

如何避免使用硬编码密钥。我试过像这样使用 listKeys:

SharedAccessKey=${listKeys(service_bus.id, service_bus.apiVersion).value[0].primaryKey}

但这行不通,对此的变体也失败了。

如果我没记错的话,服务总线的 listKeys 二头肌功能映射到 Namespaces - Authorization Rules - List Keys

您需要在 listKeys 方法调用中包含 AuthorizationRules/{authorizationRuleName}。对于 authorizationRuleName 你可以使用 RootManageSharedAccessKey.

我不确定这是否可行(我第一次玩二头肌),但你可以试一试:

var listKeysEndpoint = '${service_bus.id}/AuthorizationRules/RootManageSharedAccessKey'
SharedAccessKey=${listKeys(listKeysEndpoint, service_bus.apiVersion).primaryKey}

您也可以试试:

var serviceBusEndpoint = '${service_bus.id}/AuthorizationRules/RootManageSharedAccessKey'
var serviceBusConnectionString = listKeys(serviceBusEndpoint, service_bus.apiVersion).primaryConnectionString

获取服务总线的连接字符串。