The AWS Command Line Interface (CLI) allows you to manage AWS services. Using the CLI from your terminal interactively allows you to half-automate tasks and frees you from logging into the AWS Management Console. In addition, integrating the CLI into shell scripts allows you to automate your infrastructure and the configuration of EC2 instances during the boot process.
This article covers typical hurdles when using the AWS CLI.
1. Command Completion
When using the CLI interactively within your terminal, command completion is a killer feature you should not miss. When enabled, Command Completion allows you to use the TAB key to complete commands. This will speed up your CLI usage significant.
The following steps are needed to enable Command Completion for bash on OS X:
echo “complete -C aws_completer aws” >> ~/.bash_profile
Theofficial documentation contains general instructions for other shells as well.
2. Filtering results of requests on server-side
By default, the CLI uses a page size of 1000 and retrieves all available items. If you need to request items from a list of more than 1000 items or if you want to speed up your commands, it is a good idea to filter the results of your request on server-side.
list-* commands support server-side filtering:
--filter . For example, it is possible to filter EC2 instances by instance type:
$ aws ec2 describe-instances --filter Name=instance-type,Values=t2.nano
3. Filtering output on client-side
Another useful feature of the CLI is filtering the output of any command on client-side:
--query. The JMESpath query language is used for filtering.
The following example lists all VPCs within a region and filters the results by using a [color=red]
$ aws ec2 describe-vpcs --query "Vpcs[?VpcId == 'vpc-aaa22bbb'].CidrBlock" [ "184.108.40.206/16" ]
You might need the CIDR of a VPC as a variable in your shell script. The following example shows how to achieve that. Formatting the output as text by adding the parameter
--output text removes
--" character from the JSON result.
#!/bin/bash CIDR=$(aws ec2 describe-vpcs --query "Vpcs[?VpcId == 'vpc-aaa22bbb'].CidrBlock" --output text) echo $CIDR
4. Wait for …
When writing shell scripts by using the CLI, there will be the need to wait for a specific condition from time to time. For example, after initiating an EBS snapshot, your script might need to wait until the snapshot was completed. Waiting can be achieved with a polling loop and a
describe-* command. But there is a simpler solution built into the CLI for this:
aws <service> wait <condition> .
The following example contains a wait command that will block the script until the snapshot has been completed.
#!/bin/bash echo "Waiting for EBS snapshot" aws ec2 wait snapshot-completed --snapshot-ids snap-aabbccdd echo "EBS snapshot completed"
5. Assuming an IAM role
The CLI supports assuming an IAM role. Very handy if you need to switch between multiple AWS accounts with the help of cross-account roles.
All you need to do is to configure two profiles in
~/.aws/config: an IAM user and an IAM role profile.
[color=red]`[profile iam-user]`[/color] output = json region = eu-west-1 [color=red]`[profile iam-role]`[/color] role_arn = arn:aws:iam::<ACCOUNT_ID>:role/<IAM_ROLE> source_profile = iam-user output = json region = eu-west-1
Only the IAM user needs security credentials stored in
[color=red]`[iam-user]`[/color] aws_access_key_id = *** aws_secret_access_key = ***
Afterward, you are able to assume the IAM role by adding
--profile iam-role to your CLI commands.
6. Fine-tuning S3 config
The AWS CLI includes transfer commands for S3:
cp, sync, mv, and rm. You are able to fine-tune these commands with special configuration.
For exampl,e if you need to sync a large number of small files to S3, increasing the following values added to your
~/.aws/config config file will speed up the sync process.
[profile default] ... s3 = max_concurrent_requests = 100 max_queue_size = 10000 use_accelerate_endpoint = true
The official documentation contains detailed information about additional S3 configuration values.