As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
Tutorial: Usar script de dados e metadados de instância para recuperar o estado do ciclo de vida
Uma maneira comum de criar ações personalizadas para hooks do ciclo de vida é por meio de notificações que o Amazon EC2 Auto Scaling envia para outros serviços, como o Amazon EventBridge. No entanto, usando um script de dados do usuário para mover o código que configura instâncias e conclui a ação do ciclo de vida para as próprias instâncias, você pode evitar a necessidade de criar infraestrutura adicional.
O tutorial a seguir mostra como começar a usar um script de dados do usuário e metadados de instância. Você cria uma configuração básica de grupo do Auto Scaling com um script de dados do usuário que lê o estado de destino do ciclo de vida das instâncias em seu grupo e executa uma ação de retorno de chamada em uma fase específica do ciclo de vida de uma instância para continuar o processo de execução.
A ilustração a seguir resume o fluxo de um evento de aumento a escala horizontalmente quando você usa um script de dados do usuário para executar uma ação personalizada. Depois da execução de uma instância, o ciclo de vida da instância é pausado até que o hook do ciclo de vida seja concluído, seja por tempo limite ou pelo Amazon EC2 Auto Scaling recebendo um sinal para continuar.
Conteúdo
- Etapa 1: criar uma função do IAM com permissões para concluir ações do ciclo de vida
- Etapa 2: criar um modelo de execução e incluir a função do IAM e um script de dados de usuário
- Etapa 3: criar um grupo do Auto Scaling
- Etapa 4: Adicionar um hook do ciclo de vida
- Etapa 5: testar e verificar a funcionalidade
- Etapa 6: limpar
- Recursos relacionados
Etapa 1: criar uma função do IAM com permissões para concluir ações do ciclo de vida
Quando você usa a AWS CLI ou um AWS SDK para enviar um retorno de chamada a fim de concluir ações do ciclo de vida, é necessário usar uma função do IAM com permissões para concluir ações do ciclo de vida.
Para criar a política
-
Abra a página Policies
(Políticas) do console do IAM e escolha Create policy (Criar política). -
Selecione a guia JSON.
-
Na caixa Policy Document (Documento de política), copie e cole o seguinte documento de política. Substitua
samples text
(texto de amostra) pelo número da sua conta e o nome do grupo do Auto Scaling que deseja criar (TestAutoScalingEvent-group
).{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "autoscaling:CompleteLifecycleAction" ], "Resource": "arn:aws:autoscaling:*:
123456789012
:autoScalingGroup:*:autoScalingGroupName/TestAutoScalingEvent-group
" } ] } -
Escolha Próximo.
-
Em Nome da política, insira
TestAutoScalingEvent-policy
. Escolha Criar política.
Quando você terminar de criar a política, poderá criar uma função que a utilize.
Para criar a função
-
No painel de navegação à esquerda, escolha Roles (Funções).
-
Selecione Criar função.
-
Em Select trusted entity (Selecionar entidade confiável), escolha AWS Service (Serviço).
-
Para seu caso de uso, escolha EC2 e escolha Next (Próximo).
-
Em Attach permissions (Anexar permissões), escolha a política que você criou (TestAutoScalingEvent-policy). Em seguida, escolha Próximo.
-
Na página Name, review, and create (Nomear, revisar e criar), em Role name (Nome da função), insira
TestAutoScalingEvent-role
e escolha Create role (Criar função).
Etapa 2: criar um modelo de execução e incluir a função do IAM e um script de dados de usuário
Crie um modelo de execução para usar com seu grupo do Auto Scaling. Inclua a função do IAM que você criou e a amostra de script de dados do usuário fornecida.
Para criar um modelo de execução
-
Abra a página Launch templates
(Modelos de execução) do console do Amazon EC2. -
Escolha Criar modelo de execução.
-
Para o Launch template name (Nome do modelo de execução), insira
TestAutoScalingEvent-template
. -
Em Auto Scaling guidance (Guia do Auto Scaling), marque a caixa de seleção.
-
Para Para Imagens de aplicativo e SO (Amazon Machine Image), escolha Amazon Linux 2 (HVM), SSD Volume Type, 64 bits (x86) na lista Quick Start (Início rápido).
-
Em Instance type (Tipo de instância), escolha um tipo de instância do Amazon EC2 (p. ex., “t2.micro”).
-
Em Advanced details (Detalhes avançados), expanda a seção para visualizar os campos.
-
Em IAM instance profile, (Perfil de instância do IAM), escolha o nome do perfil de instância do IAM do seu perfil do IAM (TestAutoScalingEvent-role). Um perfil de instância é um contêiner para uma função do IAM que permite ao Amazon EC2 passar a função do IAM para uma instância quando ela é iniciada.
Se tiver criado uma função do IAM usando o console do IAM, o console terá criado automaticamente um perfil da instância e dará a esse perfil o mesmo nome da função correspondente.
-
Em User data (Dados do usuário), copie e cole a seguinte amostra de script de dados de usuário no campo. Substitua o texto de amostra de
group_name
pelo nome do grupo do Auto Scaling que deseja criar eregion
pela Região da AWS que deseja que seu grupo do Auto Scaling use.#!/bin/bash function get_target_state { echo $(curl -s http://169.254.169.254/latest/meta-data/autoscaling/target-lifecycle-state) } function get_instance_id { echo $(curl -s http://169.254.169.254/latest/meta-data/instance-id) } function complete_lifecycle_action { instance_id=$(get_instance_id) group_name='
TestAutoScalingEvent-group
' region='us-west-2
' echo $instance_id echo $region echo $(aws autoscaling complete-lifecycle-action \ --lifecycle-hook-nameTestAutoScalingEvent-hook
\ --auto-scaling-group-name $group_name \ --lifecycle-action-result CONTINUE \ --instance-id $instance_id \ --region $region) } function main { while true do target_state=$(get_target_state) if [ \"$target_state\" = \"InService\" ]; then# Change hostname
export new_hostname="${group_name}-$instance_id" hostname $new_hostname# Send callback
complete_lifecycle_action break fi echo $target_state sleep 5 done } mainEsse script de dados de usuário simples faz o seguinte:
-
Chama os metadados da instância para recuperar o estado de destino do ciclo de vida e o ID da instância nos metadados da instância
-
Recupera o estado de destino do ciclo de vida repetidamente até que ele mude para
InService
-
Altera o nome de host da instância para o ID da instância tendo como prefixo o nome do grupo do Auto Scaling, se o estado de destino do ciclo de vida for
InService
-
Envia um retorno de chamada chamando o comando complete-lifecycle-action da CLI para sinalizar o Amazon EC2 Auto Scaling a
CONTINUE
o processo de execução do EC2
-
-
Escolha Criar modelo de execução.
-
Na página de confirmação, escolha Create Auto Scaling group (Criar grupo do Auto Scaling).
nota
Para outros exemplos que você pode usar como referência para desenvolver seu script de dados de usuário, consulte o repositório do GitHub
Etapa 3: criar um grupo do Auto Scaling
Depois de criar seu modelo de execução, crie um grupo do Auto Scaling.
Para criar um grupo do Auto Scaling
-
Na página Choose launch template or configuration (Escolher o modelo ou a configuração de execução), em Auto Scaling group name (Nome do grupo do Auto Scaling), insira um nome para o grupo do Auto Scaling (
TestAutoScalingEvent-group
). -
Escolha Next (Próximo) e acesse a página Choose instance launch options (Escolher as opções de execução de instância).
-
Em Network (Rede), selecione uma VPC.
-
Em Availability Zones and subnets (Zonas de disponibilidade e sub-redes), escolha uma ou mais sub-redes de uma ou mais zonas de disponibilidade.
-
Na seção Instance type requirements (Requisitos de tipo de instância), use a configuração padrão para simplificar essa etapa. (Não substitua o modelo de execução.) Neste tutorial, você fará o execução de apenas uma das Instâncias sob demanda usando o tipo de instância especificado no modelo de execução.
-
Selecione Skip to review (Pular para a revisão) na parte inferior da tela.
-
Na página Review (Revisar), reveja as configurações do grupo do Auto Scaling e escolha Create Auto Scaling group (Criar grupo do Auto Scaling).
Etapa 4: Adicionar um hook do ciclo de vida
Adicione um hook do ciclo de vida para manter a instância em um estado de espera até que a ação do ciclo de vida esteja concluída.
Para adicionar um hook do ciclo de vida
-
Abra a página de grupos do Auto Scaling
do console do Amazon EC2. -
Marque a caixa de seleção ao lado do seu grupo do Auto Scaling. Um painel dividido é aberto na parte inferior da página.
-
No painel inferior, na guia Instance management (Gerenciamento de instâncias), em Lifecycle hooks (Hooks do ciclo de vida), escolha Create lifecycle hook (Criar hook do ciclo de vida).
-
Para definir um hook do ciclo de vida para expansão (execução de instâncias), faça o seguinte:
-
Em Lifecycle hook name (Nome do hook do ciclo de vida), insira
TestAutoScalingEvent-hook
. -
Em Lifecycle transition (Transição do ciclo de vida), escolha Instance launch (Início da instância).
-
Em Heartbeat timeout (Tempo limite de pulsação), insira
300
para o número de segundos de espera por um retorno de chamada do seu script de dados de usuário. -
Em Default result (Resultado padrão), escolha ABANDON (Abandono). Se o hook expirar sem receber um retorno de chamada do script de dados de usuário, o grupo do Auto Scaling encerrará a nova instância.
-
(Opcional) Mantenha Notification metadata (Metadados de notificação) em branco.
-
-
Escolha Criar.
Etapa 5: testar e verificar a funcionalidade
Para testar a funcionalidade, atualize o grupo do Auto Scaling aumentando em 1 a capacidade desejada do grupo do Auto Scaling. O script de dados de usuário é executado e começa a verificar o estado de destino do ciclo de vida da instância logo após a execução da instância. O script altera o nome do host e envia uma ação de retorno de chamada quando o estado de destino do ciclo de vida for InService
. Isso geralmente leva apenas alguns segundos para terminar.
Para aumentar o tamanho de grupo do Auto Scalin
-
Abra a página de grupos do Auto Scaling
do console do Amazon EC2. -
Marque a caixa de seleção ao lado do seu grupo do Auto Scaling. Veja os detalhes em um painel inferior enquanto ainda vê as linhas superiores do painel superior.
-
No painel inferior, na guia Details (Detalhes), escolha Group details (Detalhes do grupo, Edit (Editar).
-
Em Desired capacity (Capacidade desejada), aumente o valor atual em 1.
-
Selecione Atualizar. Enquanto a instância está sendo iniciada ou terminada, a coluna Status no painel superior exibe um status Updating capacity (Atualizando capacidade).
Após aumentar a capacidade desejada, você pode verificar na descrição das ações de escalabilidade se sua instância foi executada com êxito e não foi encerrada.
Para visualizar as atividades de escalabilidade
-
Retorne á página Auto Scaling groups (Grupos do Auto Scaling) e selecione seu grupo.
-
Na guia Activity (Atividade), em Activity history (Histórico de atividades), a coluna Status exibe se o seu grupo do Auto Scaling iniciou uma instância com êxito.
-
Se o script de dados de usuário falhar, você observará uma ação de escalabilidade com um status de
Canceled
e uma mensagem de status deInstance failed to complete user's Lifecycle Action: Lifecycle Action with token e85eb647-4fe0-4909-b341-a6c42EXAMPLE was abandoned: Lifecycle Action Completed with ABANDON Result
após o término do período de tempo limite.
Etapa 6: limpar
Se tiver terminado de trabalhar com os recursos que criou exclusivamente para este tutorial, siga as etapas abaixo para excluí-los.
Para excluir o hook do ciclo de vida
-
Abra a página de grupos do Auto Scaling
do console do Amazon EC2. -
Marque a caixa de seleção ao lado do seu grupo do Auto Scaling.
-
Na guia Instance management (Gerenciamento de instâncias), em Lifecycle hooks (Hooks do ciclo de vida), escolha o hook do ciclo de vida (
TestAutoScalingEvent-hook
). -
Escolha Ações, Excluir.
-
Para confirmar, escolha Delete (Excluir) novamente.
Para excluir o modelo de execução
-
Abra a página Launch templates
(Modelos de execução) do console do Amazon EC2. -
Selecione seu modelo de execução (
TestAutoScalingEvent-template
) e escolha Actions (Ações), Delete template (Excluir modelo). -
Quando a confirmação for solicitada, digite
Delete
para confirmar a exclusão do modelo de execução especificado e, em seguida, escolha Excluir.
Se tiver terminado de trabalhar com o grupo de exemplo do Auto Scaling, exclua-o. Você também pode excluir a função do IAM e a política de permissões que criou.
Para excluir o grupo do Auto Scaling
-
Abra a página de grupos do Auto Scaling
do console do Amazon EC2. -
Marque a caixa de seleção ao lado do seu grupo do Auto Scaling (
TestAutoScalingEvent-group
) e escolha Delete (Excluir). -
Quando a confirmação for solicitada, digite
delete
para confirmar a exclusão do grupo do Auto Scaling especificado e, em seguida, escolha Excluir.Um ícone de carregamento na coluna Name (Nome) indica que o grupo do Auto Scaling está sendo excluído. É necessário aguardar alguns minutos para encerrar a instância e excluir o grupo.
Para excluir a função do IAM
-
Abra a página Roles
(Funções) no console do IAM. -
Selecione o papel da função (
TestAutoScalingEvent-role
). -
Escolha Excluir.
-
Quando for solicitada confirmação, digite o nome da função e escolha Excluir.
Para excluir a política do IAM
-
Abra a página Policies
(Políticas) do console do IAM. -
Selecione a política que você criou (
TestAutoScalingEvent-policy
). -
Escolha Ações, Excluir.
-
Quando for solicitada confirmação, digite o nome da política e escolha Excluir.
Recursos relacionados
Os tópicos relacionados a seguir podem ser úteis à medida que você desenvolve um código que invoca ações em instâncias com base nos dados disponíveis nos metadados da instância.
-
Recuperar o estado de destino do ciclo de vida por meio de metadados de instância. Esta seção descreve o estado do ciclo de vida de outros casos de uso, como o encerramento da instância.
-
Adicionar hooks do ciclo de vida (console). Este procedimento mostra como adicionar hooks do ciclo de vida tanto para expansão (execução de instâncias) quanto para redução (instâncias encerrando ou retornando a um grupo de aquecimento).
-
Categorias de metadados de instância no Guia do usuário do Amazon EC2 para instâncias do Linux. Este tópico lista todas as categorias de metadados de instância que você pode usar para invocar ações em instâncias do EC2.
Para ver um tutorial que mostra como usar o Amazon EventBridge para criar regras que invocam funções do Lambda com base em eventos que acontecem nas instâncias do seu grupo do Auto Scaling, consulte Tutorial: Configurar um hook do ciclo de vida que invoca uma função do Lambda.