Exemplos para criação e gerenciamento de modelos de execução com a AWS CLI
Você pode criar e gerenciar modelos de execução usando o Console de gerenciamento da AWS, AWS Command Line Interface ou (AWS CLI) SDKs. Esta seção mostra exemplos de criação e gerenciamento de modelos de execução para o Amazon EC2 Auto Scaling na AWS CLI.
Conteúdo
Exemplo de uso
{ "LaunchTemplateName": "my-template-for-auto-scaling", "VersionDescription": "test description", "LaunchTemplateData": { "ImageId": "ami-04d5cc9b88example", "InstanceType": "t2.micro", "SecurityGroupIds": [ "sg-903004f88example" ], "KeyName": "MyKeyPair", "Monitoring": { "Enabled": true }, "Placement": { "Tenancy": "dedicated" }, "CreditSpecification": { "CpuCredits": "unlimited" }, "MetadataOptions": { "HttpTokens": "required", "HttpPutResponseHopLimit": 1, "HttpEndpoint": "enabled" } } }
Criar um modelo de execução básico
Para criar um modelo de execução básico, use o comando create-launch-template
-
Substitua
ami-04d5cc9b88examplepelo ID da AMI a partir da qual as instâncias serão inicializadas. -
Substitua
t2.micropor um tipo de instância compatível com a AMI especificada.
Este exemplo cria um modelo de execução com o nome my-template-for-auto-scaling. Se as instâncias criadas por esse modelo de execução forem executadas em uma VPC padrão, elas receberão um endereço IP público por padrão. Se as instâncias forem executadas em uma VPC não padrão, elas não receberão um endereço IPv4 público por padrão.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Para obter mais informações sobre como citar parâmetros formatados em JSON, consulte Uso de aspas com strings na AWS CLI no Manual do usuário da AWS Command Line Interface.
Como alternativa, é possível especificar os parâmetros formatados em JSON em um arquivo de configuração.
O exemplo a seguir cria um modelo de execução básico, fazendo referência a um arquivo de configuração para valores de parâmetro de modelo de execução.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data file://config.json
Conteúdo de config.json:
{ "ImageId":"ami-04d5cc9b88example", "InstanceType":"t2.micro" }
Especificar etiquetas que marcam instâncias ao iniciar
O exemplo a seguir adiciona uma tag (por exemplo, purpose=webserver) a instâncias na execução.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"TagSpecifications":[{"ResourceType":"instance","Tags":[{"Key":"purpose","Value":"webserver"}]}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
nota
Se você especificar tags de instância em seu modelo de execução e optar por propagar tags de seu grupo do Auto Scaling para suas instâncias, todas as tags serão mescladas. Se a mesma chave da etiqueta for especificada para uma etiqueta no modelo de execução e uma etiqueta no grupo do Auto Scaling, então, o valor da etiqueta do grupo terá precedência.
Especificar um perfil do IAM a ser transmitido às instâncias
O exemplo a seguir especifica o nome do perfil da instância associada ao perfil do IAM a ser passado às instâncias na execução. Para obter mais informações, consulte Perfis do IAM para aplicações que são executadas em instâncias do Amazon EC2.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"IamInstanceProfile":{"Name":"my-instance-profile"},"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Atribuir um endereço IP público
O exemplo create-launch-template
nota
Quando você especificar uma interface de rede, especifique um valor para Groups que corresponda aos grupos de segurança da VPC nos quais seu grupo do Auto Scaling iniciará instâncias. Especifique as sub-redes da VPC como propriedades do grupo do Auto Scaling.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"NetworkInterfaces":[{"DeviceIndex":0,"AssociatePublicIpAddress":true,"Groups":["sg-903004f88example"],"DeleteOnTermination":true}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Especificar um script de dados do usuário que configura instâncias ao iniciar
O exemplo a seguir especifica um script de dados do usuário como uma string codificada em base64 que configura instâncias na execução. O comando create-launch-template
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"UserData":"IyEvYmluL2Jhc...","ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Especificar um mapeamento de dispositivos de blocos
O exemplo create-launch-template/dev/xvdcz. O volume /dev/xvdcz usa o tipo de volume SSD de uso geral (gp2) e é excluído ao terminar a instância à qual ele está anexado.
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"BlockDeviceMappings":[{"DeviceName":"/dev/xvdcz","Ebs":{"VolumeSize":22,"VolumeType":"gp2","DeleteOnTermination":true}}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Especificar hosts dedicados para trazer licenças de software de fornecedores externos
Se você especificar locação de host, você pode especificar um grupo de recursos de host e uma configuração licenças de License Manager para trazer licenças de software qualificáveis de fornecedores externos. Em seguida, você pode usar as licenças em instâncias do EC2 usando o seguinte comando create-launch-template
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"Placement":{"Tenancy":"host","HostResourceGroupArn":"arn"},"LicenseSpecifications":[{"LicenseConfigurationArn":"arn"}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Especificar uma interface de rede existente
O seguinte exemplo de create-launch-template
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"NetworkInterfaces":[{"DeviceIndex":0,"NetworkInterfaceId":"eni-b9a5ac93","DeleteOnTermination":false}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Criar várias interfaces de rede
O seguinte exemplo de create-launch-template
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"NetworkInterfaces":[{"DeviceIndex":0,"Groups":["sg-903004f88example"],"DeleteOnTermination":true},{"DeviceIndex":1,"Groups":["sg-903004f88example"],"DeleteOnTermination":true}],"ImageId":"ami-04d5cc9b88example","InstanceType":"t2.micro"}'
Se você usar um tipo de instância que ofereça suporte a várias placas de rede e a Elastic Fabric Adapters (EFAs), poderá adicionar uma interface secundária a uma placa de rede secundária e habilitar o EFA usando o seguinte comando create-launch-template
aws ec2 create-launch-template --launch-template-namemy-template-for-auto-scaling--version-descriptionversion1\ --launch-template-data '{"NetworkInterfaces":[{"NetworkCardIndex":0,"DeviceIndex":0,"Groups":["sg-7c2270198example"],"InterfaceType":"efa","DeleteOnTermination":true},{"NetworkCardIndex":1,"DeviceIndex":1,"Groups":["sg-7c2270198example"],"InterfaceType":"efa","DeleteOnTermination":true}],"ImageId":"ami-09d95fab7fexample","InstanceType":"p4d.24xlarge"}'
Atenção
O tipo de instância p4d.24xlarge incorre em custos mais altos do que os outros exemplos desta seção. Para obter mais informações sobre Ipreços de instâncias P4d, consulte Preços de instâncias P4d do Amazon EC2
nota
Anexar várias interfaces de rede da mesma sub-rede a uma instância pode introduzir roteamento assimétrico, especialmente em instâncias que us~em uma variante do Linux que não seja da Amazon. Se você precisar desse tipo de configuração, deverá configurar a interface de rede secundária dentro do sistema operacional. Como exemplo, consulte Como posso fazer minha interface de rede secundária funcionar na minha instância do Ubuntu EC2?
Gerenciar modelos de execução
A AWS CLI inclui vários outros comandos que ajudam você a gerenciar seus modelos de execução.
Conteúdo
Listar e descrever modelos de execução
Você pode usar dois comandos da AWS CLI para obter informações sobre seus modelos de execução:describe-launch-templates
O comando describe-launch-templates
O exemplo a seguir fornece um resumo do modelo de execução especificado.
aws ec2 describe-launch-templates --launch-template-namesmy-template-for-auto-scaling
O seguinte é um exemplo de resposta.
{
"LaunchTemplates": [
{
"LaunchTemplateId": "lt-068f72b729example",
"LaunchTemplateName": "my-template-for-auto-scaling",
"CreateTime": "2020-02-28T19:52:27.000Z",
"CreatedBy": "arn:aws:iam::123456789012:user/Bob",
"DefaultVersionNumber": 1,
"LatestVersionNumber": 1
}
]
}
Se você não usar a opção --launch-template-names para limitar a saída a um modelo de execução, informações sobre todos os modelos de execução serão retornadas.
O seguinte comando describe-launch-template-version
aws ec2 describe-launch-template-versions --launch-template-idlt-068f72b729example
O seguinte é um exemplo de resposta.
{
"LaunchTemplateVersions": [
{
"VersionDescription": "version1",
"LaunchTemplateId": "lt-068f72b729example",
"LaunchTemplateName": "my-template-for-auto-scaling",
"VersionNumber": 1,
"CreatedBy": "arn:aws:iam::123456789012:user/Bob",
"LaunchTemplateData": {
"TagSpecifications": [
{
"ResourceType": "instance",
"Tags": [
{
"Key": "purpose",
"Value": "webserver"
}
]
}
],
"ImageId": "ami-04d5cc9b88example",
"InstanceType": "t2.micro",
"NetworkInterfaces": [
{
"DeviceIndex": 0,
"DeleteOnTermination": true,
"Groups": [
"sg-903004f88example"
],
"AssociatePublicIpAddress": true
}
]
},
"DefaultVersion": true,
"CreateTime": "2020-02-28T19:52:27.000Z"
}
]
}
Criar uma versão de modelo de execução
O seguinte comando create-launch-template-version
aws ec2 create-launch-template-version --launch-template-idlt-068f72b729example--version-descriptionversion2\ --source-version1--launch-template-data "ImageId=ami-c998b6b2example"
Para definir a versão padrão do modelo de execução, use o comando modificar-launch-template
Excluir uma versão de modelo de execução
O seguinte comando delete-launch-template-version
aws ec2 delete-launch-template-versions --launch-template-idlt-068f72b729example--versions 1
Excluir um modelo de execução
Se você não precisar mais de um modelo de execução, exclua-o usando o seguinte comando delete-launch-template
aws ec2 delete-launch-template --launch-template-idlt-068f72b729example
Atualizar um grupo do Auto Scaling para usar um modelo de execução
Você pode usar o comando update-auto-scaling-group
Atualizar um grupo do Auto Scaling para usar a versão mais recente de um modelo de execução
O seguinte comando update-auto-scaling-group
aws autoscaling update-auto-scaling-group --auto-scaling-group-namemy-asg\ --launch-template LaunchTemplateId=lt-068f72b729example,Version='$Latest'
Atualizar um grupo do Auto Scaling para usar uma versão específica de um modelo de execução
O seguinte comando update-auto-scaling-group
aws autoscaling update-auto-scaling-group --auto-scaling-group-namemy-asg\ --launch-template LaunchTemplateName=my-template-for-auto-scaling,Version='2'