Partilhar via


Guia de início rápido: implantar o Azure AI Video Indexer (VI) usando o Bicep

Usando este início rápido, você pode criar uma conta do Azure AI Video Indexer (VI) usando o Bicep.

Os seguintes recursos são instalados usando o modelo Bicep:

  • Conta do Armazenamento do Azure. As contas de armazenamento para VI devem ser uma conta de armazenamento v2 de uso geral padrão.
  • Conta VI com uma conexão com a conta de armazenamento usando uma identidade gerenciada atribuída ao sistema
  • A atribuição da função Contribuidor de Dados de Blob de Armazenamento para a conta VI na conta de armazenamento

Pré-requisitos

  • Uma assinatura do Azure com permissão para criar recursos.
  • A versão mais recente da CLI do Azure.
  • Recomendado: Ferramentas de bíceps.

Revise o arquivo Bicep

O código que acompanha este início rápido pode ser encontrado nos Exemplos Oficiais do Indexador de Vídeo do Azure AI.

O main.bicep arquivo orquestra a instalação de dois módulos:

  • O módulo VI que implanta a conta VI com seu recurso de conta de Armazenamento do Azure dependente.
  • O módulo de Permissão de Função que concede à identidade VI a permissão de Proprietário de Dados de Armazenamento de Blob do Azure na conta de armazenamento.

Nota

É uma boa prática separar os recursos do Azure em vários módulos do Bicep. Para obter uma compreensão abrangente de como os módulos Bicep funcionam, consulte Módulos Bicep - Azure Resource Manager.

Criar o arquivo Bicep

  1. Copie e cole o seguinte conteúdo em um arquivo chamado main.bicep em seu diretório de trabalho.

    param location string = resourceGroup().location 
    @description('Storage Account Name') 
    param storageAccountName string = “<add_your_storage_account_name” 
    @description('Video Indexer Account Name') 
    param videoIndexerAccountName string = = “<add_your_videoindexer_account_name>” 
    
    module videoIndexer 'videoIndexer.bicep' = { 
      name: 'videoIndexer.bicep' 
      params: { 
        location: location 
        storageAccountName: storageAccountName 
        videoIndexerAccountName: videoIndexerAccountName 
      } 
    } 
    
    // Role Assignment must be on a separate resource  
    
    module roleAssignment 'role-assignment.bicep' = { 
      name: 'grant-storage-blob-data-contributor' 
      params: { 
        servicePrincipalObjectId: videoIndexer.outputs.servicePrincipalId 
        storageAccountName: storageAccountName 
      } 
      dependsOn: [ 
        videoIndexer 
      ] 
    } 
    
    
  2. Edite o main.bicep ficheiro preenchendo os parâmetros em falta:

    • storageAccountName - o nome da conta de armazenamento que você deseja conectar à conta do Azure AI Video Indexer
    • videoIndexerAccountName - o nome da conta VI

Criar um módulo Bicep Video AI Indexer

Copie e cole o seguinte conteúdo em um arquivo chamado videoindexer.bicep em seu diretório de trabalho. O arquivo implanta a conta de armazenamento junto com uma conta VI com uma identidade atribuída ao sistema.


param location string = resourceGroup().location 
@description('Storage Account Name') 
param storageAccountName string 
@description('Video Indexer Account Name') 
param videoIndexerAccountName string 
@description('Storage Account Kind') 
var storageKind = 'StorageV2' 
@description('Storage Account Sku') 
var storageSku = 'Standard_LRS' 
resource storageAccount 'Microsoft.Storage/storageAccounts@2021-04-01' = { 
  name: storageAccountName 
  location: location 
  kind: storageKind 
  properties: { 
    minimumTlsVersion: 'TLS1_2' 
  } 
  sku: { 
    name: storageSku 
  }
} 

resource videoIndexer 'Microsoft.VideoIndexer/accounts@2024-01-01' = { 
  name: videoIndexerAccountName 
  location: location 
  identity: { 
    type: 'SystemAssigned' 
  } 

  properties: { 
    storageServices: { 
      resourceId: storageAccount.id 
    } 
  } 
} 

output storageAccountName string = storageAccount.name 
output accountName string = videoIndexer.name 
output servicePrincipalId string = videoIndexer.identity.principalId 

Criar um módulo Bicep de atribuição de função

Copie e cole o conteúdo a seguir em um arquivo chamado role-assignment.bicep em seu diretório de trabalho. O módulo concede à identidade atribuída ao sistema a função de Contribuidor de Dados de Blob de Armazenamento na conta de armazenamento da conta VI.


@secure() 
param servicePrincipalObjectId string 
param storageAccountName string
@description('Storage Blob Data Contributor Role Id') 
var storageBlobDataContributorRoleId = 'ba92f5b4-2d11-453d-a403-e96b0029c9fe' 
resource storageAccount 'Microsoft.Storage/storageAccounts@2021-04-01' existing= { 
  name: storageAccountName 
} 

resource roleAssignment 'Microsoft.Authorization/roleAssignments@2020-04-01-preview' = { 
  name: guid(storageAccount.id, servicePrincipalObjectId, 'Storage Blob Data Contributor')  
  scope: storageAccount  
  properties: { 
    roleDefinitionId: subscriptionResourceId('Microsoft.Authorization/roleDefinitions', storageBlobDataContributorRoleId)  
    principalId: servicePrincipalObjectId 
    principalType: 'ServicePrincipal'
  }
} 

Implantar os arquivos Bicep

  1. Abra um terminal e certifique-se de que tem sessão iniciada na sua subscrição do Azure.

    az login

    az account set --subscription <your-subscription-name>

  2. Crie um grupo de recursos.

    az group create -n <your-resource-group-name> -l eastus

  3. Implantar o modelo no grupo de recursos.

    az deployment group create --resource-group <your-resource-group-name> --template-file .\main.template.json

  4. Aguarde a conclusão da implantação e inspecione o recurso criado no portal do Azure.

Se você é novo no Azure AI Video Indexer, consulte:

Se você é novo na implantação do Bicep, consulte: