Resolva erros de recursos pai

Este artigo descreve o erro ParentResourceNotFound que você pode se obter durante a implantação de um recurso que é dependente de um recurso pai. O erro ocorre quando você implanta recursos com um arquivo Bicep ou modelo do ARM (modelo do Azure Resource Manager).

Sintoma

Ao implantar um recurso que é filho de outro recurso, você pode receber o seguinte erro:

Code=ParentResourceNotFound,
Message=Can not perform requested operation on nested resource. Parent resource 'exampleserver' not found."

Causa

Quando um recurso é filho de outro recurso, o recurso pai deve existir antes da criação do recurso filho. O nome do recurso filho define a conexão com o recurso pai. O formato do nome do recurso filho está no formato <parent-resource-name>/<child-resource-name>. Por exemplo, um Banco de Dados SQL pode ser definido como:

resource sqlDatabase 'Microsoft.Sql/servers/databases@2022-02-01-preview' = {
  name: '${sqlServerName}/${databaseName}'
  ...
}

Para saber mais sobre recursos pai e filho no Bicep, confira Definir o nome e o tipo de recursos filho no Bicep.

Se você implantar o servidor e o banco de dados no mesmo modelo, mas não especifica uma dependência no servidor, a implantação de banco de dados talvez seja iniciado antes que o servidor tenha sido implantado. Isso faz com que a implantação do banco de dados falhe com o erro ParentResourceNotFound.

Se o recurso pai já existe e não será implantado no mesmo modelo, você receber esse erro ParentResourceNotFound quando o Gerenciador de Recursos não é possível associar o recurso filho com o pai. Esse erro pode acontecer quando o recurso filho não estiver no formato correto. Ou se o recurso filho for implantado em um grupo de recursos diferente do grupo de recursos para o recurso pai.

Solução 1: implantar no mesmo modelo

Para resolver esse erro quando recursos pai e filho são implantados no mesmo modelo, inclua uma dependência.

Este exemplo usa um recurso filho aninhado dentro do recurso pai e isso cria a dependência. O filho obtém o tipo de recurso e a versão da API do recurso pai.

resource sqlServer 'Microsoft.Sql/servers@2022-02-01-preview' = {
  name: sqlServerName
  properties: {
    ...
  }
  resource sqlDatabase 'databases' = {
    name: databaseName
    ...
  }
}

Para obter mais informações sobre dependências, consulte Declaração de recursos no Bicep.

Solução 2: implantar em modelos diferentes

Para resolver esse erro quando o recurso pai foi anteriormente implantado em um modelo diferente, você não define uma dependência. Em vez disso, implante o filho no mesmo grupo de recursos e forneça o nome do recurso pai.

Este exemplo usa a palavra-chave existente para fazer referência a um pai que foi implantado em um arquivo separado. O recurso filho usa o parent elemento e o nome simbólico do recurso pai.

param location string = resourceGroup().location
param sqlServerName string
param databaseName string

resource sqlServer 'Microsoft.Sql/servers@2022-02-01-preview' existing = {
  name: sqlServerName
}

resource sqlDatabase 'Microsoft.Sql/servers/databases@2022-02-01-preview' = {
  parent: sqlServer
  name: databaseName
  location: location
}