Compartir a través de

解决存储帐户名称错误

本文描述如何使用 Bicep 文件或 Azure 资源管理器模板(ARM 模板)解决在部署期间可能出现的 Azure 存储帐户名称错误。 导致错误的常见原因包括:存储帐户名称具有无效字符,或者存储帐户使用与现有存储帐户相同的名称。 存储帐户名称在 Azure 中必须是全局唯一的。

症状

在部署期间,存储账户名称无效会导致出现错误代码。 下面是存储帐户名称错误的一些示例。

帐户名称无效

出现此错误的情况是,存储帐户名称包含禁用字符,例如大写字母或特殊字符(如感叹号)。

Code=AccountNameInvalid
Message=S!torageckrexph7isnoc is not a valid storage account name. Storage account name must be
between 3 and 24 characters in length and use numbers and lower-case letters only.

资源位置无效

出现此错误的情况是,你尝试在同一资源组中部署新的具有相同名称的存储帐户,但是使用与 Azure 订阅中的现有存储帐户不同的位置。 该错误指示已存在存储帐户且无法在新位置创建该帐户。 选择其他名称来创建新的存储账户。

Code=InvalidResourceLocation
Message=The resource 'storageckrexph7isnoc' already exists in location 'chinanorth'
in resource group 'demostorage'. A resource with the same name cannot be created in location 'chinanorth'.
Please select a new resource name.

其他资源组中的存储帐户

出现此错误的情况是,你尝试部署与现有存储帐户具有相同名称和位置的新存储帐户,但在订阅中的其他资源组中进行部署。

Code=StorageAccountInAnotherResourceGroup
Message=The account storageckrexph7isnoc is already in another resource group in this subscription.

存储帐户已被占用

出现此错误的情况是,你尝试部署与 Azure 中已有的存储帐户同名的新存储帐户。 你的订阅或租户中,或者 Azure 中的任何位置可能存在现有存储帐户名称。 存储帐户名称在 Azure 中必须是全局唯一的。

Code=StorageAccountAlreadyTaken
Message=The storage account named storageckrexph7isnoc is already taken.

原因

导致错误的常见原因是,存储帐户名称使用无效字符或名称重复。 存储帐户名称必须满足以下条件:

  • 长度介于 3 至 24 个字符之间,只包含小写字母和数字。
  • 在 Azure 中必须是全局唯一。 存储帐户名称在 Azure 中不能重复。

解决方案

可通过将前缀或后缀与 uniqueString 函数中的值进行连接来创建唯一名称。

以下示例使用与 uniqueString 中的值连接的字符串 storage 指定一个前缀。

Bicep 将字符串内插uniqueString 一起使用。

resource storageAccount 'Microsoft.Storage/storageAccounts@2021-09-01' = {
  name: 'storage${uniqueString(resourceGroup().id)}'

请确保存储帐户名称不超过 24 个字符。 uniqueString 函数返回 13 个字符。 如果要连接前缀或后缀,请提供一个不超过 11 个字符的值。

以下示例使用一个名为 storageNamePrefix 的参数,它会创建一个最多包含 11 个字符的前缀。

@description('The prefix value for the storage account name.')
@maxLength(11)
param storageNamePrefix string = 'storage'

然后,将 storageNamePrefix 参数的值与 uniqueString 值连接起来创建一个存储帐户名称。

name: '${storageNamePrefix}${uniqueString(resourceGroup().id)}'