Começar a usar o Batch

Esta página descreve como começar a usar o Batch para Google Cloud.

Visão geral

O Batch é um serviço totalmente gerenciado que permite programar, enfileirar e executar cargas de trabalho de processamento em lote nos recursos do Google Cloud . Por exemplo, use o lote para computação de alto desempenho (HPC), machine learning (ML) e cargas de trabalho de processamento de dados. O Batch provisiona recursos e gerencia a capacidade em seu nome, permitindo que suas cargas de trabalho em lote sejam executadas em escala.

Com o Batch, não é necessário configurar e gerenciar agendadores de jobs de terceiros, provisionar e desprovisionar recursos ou solicitar recursos uma zona de cada vez. Para executar um job, especifique parâmetros para os recursos necessários para sua carga de trabalho. Em seguida, o lote recebe os recursos e enfileira o job para execução. O Batch oferece integração nativa a outros serviços do Google Cloud para ajudar na programação, execução, armazenamento e análise de jobs em lote. Assim, é possível se concentrar em enviar um job e consumir os resultados.

O lote é composto pelos seguintes componentes:

  • Job:um programa programado que executa um conjunto de tarefas até a conclusão sem nenhuma interação do usuário, normalmente para cargas de trabalho computacionais. Por exemplo, um job pode ser um script de shell único ou um cálculo complexo de várias partes.

    Especificamente, um job em lote representa uma matriz de uma ou mais tarefas e o ambiente para executar essas tarefas. Você define o programa para o job como uma sequência de um ou mais executáveis. Cada tarefa executa a sequência de executáveis nos recursos do job. É possível configurar as tarefas de um job para serem executadas em paralelo ou sequencialmente.

  • Tarefa:uma execução da sequência de executáveis de um job. Quando um job tem várias tarefas, você especifica como quer que cada execução varie fazendo referência à variável de ambiente para o índice de uma tarefa nos executáveis do job.

  • Executável:um script ou contêiner executável que você define como parte de um job.

  • Recursos:a infraestrutura necessária para executar um job. No mínimo, você só precisa especificar os recursos de computação necessários por tarefa: núcleos de CPU, memória e (se necessário) armazenamento de disco de inicialização extra. Como alternativa, também é possível especificar outras opções de recursos para o job. O lote cria e exclui automaticamente os recursos que atendem às suas especificações durante o tempo de execução do job.

    Especificamente, cada job em lote é executado em um grupo gerenciado de instâncias regional (MIG), que é um grupo de uma ou mais instâncias de máquina virtual (VM) do Compute Engine correspondentes, cada uma localizada em uma das zonas incluídas. Cada VM tem hardware dedicado para núcleos e memória da CPU, que afetam o desempenho do job, e um disco de inicialização, que armazena uma imagem do sistema operacional (SO) e instruções para executar o job. Se especificado, um job também poderá incluir ou acessar recursos adicionais, por exemplo, GPUs ou volumes de armazenamento externo. O número de VMs provisionadas para um job depende dos requisitos de hardware e das opções de programação de tarefas especificadas.

Em resumo, o lote permite criar e executar jobs que provisionam e usam automaticamente os recursos necessários para executar tarefas.

Para mais informações sobre o comportamento e as opções de jobs, consulte a página Visão geral da criação e execução de jobs.

Preços

Não há custo financeiro extra para usar o serviço em lote. Você só vai pagar pelo custo dos recursos necessários para executar os jobs.

Para mais informações sobre os custos associados ao Batch e como filtrar os relatórios do Cloud Billing para conferir os custos do Batch, consulte Preços.

Restrições

O lote tem as seguintes restrições:

  • Não é possível exceder as cotas e os limites de lote do projeto.
  • Você só pode especificar um tipo de máquina, que pode ser predefinido ou personalizado, por job.
  • Não é possível especificar mais de um grupo de tarefas por job. Todos os jobs têm apenas um grupo de tarefas chamado group0.

Pré-requisitos

Para começar a usar o lote, siga os pré-requisitos abaixo:

  1. Se o projeto ainda não usou o Batch, ative o Batch para o projeto.
  2. Configure o lote para cada novo usuário.

Ativar o Batch para um projeto

Para começar a usar o Batch com um projeto, faça o seguinte:

  1. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  2. Make sure that billing is enabled for your Google Cloud project.

  3. Verifique se o lote está ativado para o projeto:

    1. Ative as APIs para lote usando o console do Google Cloud ou a Google Cloud CLI.

      Console

      Enable the Batch, Compute Engine, and Cloud Logging APIs.

      Enable the APIs

      gcloud

      Enable the Batch, Compute Engine, and Cloud Logging APIs:

      gcloud services enable batch.googleapis.com compute.googleapis.com logging.googleapis.com

    2. Verifique se o projeto tem uma ou mais contas de serviço com as permissões necessárias para criar e acessar os recursos para executar jobs em lote.

      É importante que todos os usuários que você quer permitir que criem e executem jobs em lote no projeto tenham permissão para usar uma dessas contas de serviço. Portanto, não selecione contas de serviço com mais permissões do que você quer conceder a esses usuários.

      A conta de serviço que cada job usa por padrão é a conta de serviço padrão do Compute Engine, mas você também pode personalizar a conta de serviço usada por um job.

      A menos que você planeje usar apenas a configuração padrão para as contas de serviço do job, conceda os seguintes papéis do IAM a todas as contas de serviço que seu projeto usa para jobs em lote.

      • Relator do agente em lote (roles/batch.agentReporter) no projeto
      • Para permitir que os jobs gerem registros no Cloud Logging: Logs Writer (roles/logging.logWriter) no projeto

      A conta de serviço usada para um job também pode exigir outros papéis com base nas opções de configuração que você quer usar nos jobs. Consulte a documentação de cada tarefa para saber se permissões adicionais são necessárias. Para mais informações sobre como conceder papéis a contas de serviço, consulte Como restringir contas de serviço e Gerenciar o acesso a contas de serviço.

    3. Confira se você conhece o agente de serviço de lote do seu projeto:

      Depois de criar um job em lote, o agente de serviço em lote é criado automaticamente para seu projeto com o seguinte nome:

      service-PROJECT_NUMBER@gcp-sa-cloudbatch.iam.gserviceaccount.com
      

      Substitua PROJECT_NUMBER pelo número do projeto do seu projeto.

      O agente de serviço em lote recebe automaticamente o papel do IAM de agente de serviço em lote do Google (roles/batch.serviceAgent). Essa configuração é necessária para que seu projeto use o Batch.

      No entanto, alguns casos de uso, como executar um job em uma rede VPC compartilhada, exigem que você conceda outras permissões ao agente de serviço de lote do seu projeto.

      Para mais informações, consulte Agentes de serviço.

Configurar o lote para um novo usuário

Para começar a usar o Batch como usuário, faça o seguinte:

  1. Para receber as permissões necessárias para usar o Batch, peça ao administrador para conceder a você os papéis do IAM necessários no projeto. Consulte a documentação de cada tarefa para conferir as permissões necessárias.

    Por exemplo, se você quiser começar a aprender a usar o Batch criando um job básico, solicite papéis para as seguintes tarefas:

    • Para criar trabalhos:
    • Para listar e descrever jobs: Editor de jobs em lote (roles/batch.jobsEditor) ou Leitor de jobs em lote (roles/batch.jobsViewer) no projeto
    • Para conferir os registros de jobs: Visualizador de registros (roles/logging.viewer) no projeto
    • Para excluir jobs: Editor de jobs em lote (roles/batch.jobsEditor) no projeto

    Para mais informações sobre como conceder papéis, consulte Gerenciar acesso.

  2. Se você quiser usar os exemplos de linha de comando para o Batch, configure a Google Cloud CLI seguindo estas etapas. Saiba mais sobre a autenticação da Google Cloud CLI.

    1. Install the Google Cloud CLI, then initialize it by running the following command:

      gcloud init

    2. Recomendado: defina um projeto padrão usando o comando gcloud config set project:

      gcloud config set project PROJECT_ID
      

      Substitua PROJECT_ID pelo ID do projeto do seu projeto.

  3. Se você quiser usar os exemplos de API ou de biblioteca de cliente para o Batch, consulte Autenticar para o Batch.

Receber suporte

Você pode conversar sobre o Batch com a comunidade usando o rótulo Batch nos fóruns do Cloud.

Se você tiver problemas com o lote, consulte a documentação de solução de problemas.

Para receber suporte ou enviar feedback sobre o Batch, use estes recursos:

  • Em caso de problemas de faturamento com o Google Cloud, entre em contato com osuporte de faturamento.

  • Se você tiver um pacote de suporte pago, entre em contato diretamente com o suporte do Google Cloud para resolver problemas com o Batch.

    O Google Cloud oferece pacotes de suporte diferentes para atender a diferentes necessidades, como cobertura 24 horas por dia, suporte por telefone e acesso a um gerente de suporte técnico. Para mais informações, consulte Google Cloud Suporte.

  • Para enviar feedback ou solicitar recursos para o Batch ou para informar problemas sem um pacote de suporte pago, clique no botão Enviar feedback, que fica no início e no fim de cada página da documentação do Batch. Em seguida, selecione uma das seguintes opções:

    • Para feedback relacionado à documentação do Batch, selecione "Feedback sobre a documentação".
    • Para todos os outros feedbacks sobre o Batch, selecione "Feedback sobre o produto".

A seguir