Update: 4th January 2025 - AWS CLI Profiles: about Profiles and how to configure them.
One of the main issues encountered with hosting 360˚ panoramas on AWS buckets is the time it takes to upload the thousands of multiresolution tiles that make up the panoramas. Using the AWS Console to upload 360˚ Panorama projects can be incredibly slow however using AWS CLI the speed of the upload process can be dramatically increased.
Using CLI also negates the need to open up the console to update files as the project evolves or changes.
Note: this 3 part tutorial requires you have administration access to an AWS Account
Part 1: Install takes you through Download, Installing and Testing the AWS CLI Application
Part 2: Configure shows you how to create an Identity Access Management (IAM) user, collect configuration data and configure the CLI.
Part 3: Upload shows how to upload your local files to your S3 Bucket/s and highlights some other useful Command line operations.
Configuration Data
Now that we have installed and tested our CLI Application it’s time to create our IAM user and configure the app. In order to complete the configure, there is some information that we need to have on hand to enter in the following fields;
AWS Access Key ID,
AWS Secret Access Key,
Default region name,
Default output format. (figure #1)
We can gather most of these details are from the AWS Web Console.
Gathering the Data
1. Log in to AWS (figure #2)
We will start with the Default Output format and Default Region Name
Note: the default output format refers to the way the data generated by CLI Application is presented within the Terminal window, for now, we are going to use ‘Json’ (this can be changed later if you want).
For more information on AWS CLI Output formats visit: https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output-format.html
Note: the default region name refers to the location selected by you as the place where you are storing your data and the location of your S3 buckets. Regions are located geographically around the world.
For more information on AWS Regions visit:
https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/Concepts.RegionsAndAvailabilityZones.html
2. In the main menu click on the Region name, in my example, Sydney. The location dropdown menu will highlight your region name. In my example its ap-southeast-2 (figure #3)
Next are the Access Key ID and Secret Access Key
Note: the AWS Access Key ID, AWS Secret Access Key will be part of an AWS Identity and Access Management (IAM) user’s credentials. If you don’t already have an IAM user we are going to create one.
An IAM is a web service that helps you securely control access to AWS resources. You use IAM to control who is authenticated (signed in) and authorized (has permissions) to use resources.
For more information on AWS IAM visit:
https://docs.aws.amazon.com/IAM/latest/UserGuide/introduction.html
3. In the search bar enter IAM and it will display a link to the IAM services.
4. Mouse over to view more options and click on the Users link. (figure #4)
5. Click on the ‘Add user’ button (figure #5)
6. Enter a name for IAM User and check Programmatic access for the Access type. Click on the ‘Next: Permissions’ button (figure #6)
Note: we are using Programmatic access as the IAM user will only be accessing AWS via the CLI and not via the web console.
Note: at this point we want to use the easiest way to get started so we will use a pre-built policy for the user.
7. Click on the ‘Attach existing policies directly’ button (figure #7)
8. Enter s3 into the Filter policies search field and from the results check AmazonS3FullAccess. Click on the ‘Next: Tags’ button (figure #8)
Note: this policy provides full access to the S3 buckets including the ability to delete them!
9. Click on the ‘Next: Review’ button (figure #9)
Note: in this step we will not be adding any tags.
For more information on AWS IAM Tags visit:
https://docs.aws.amazon.com/IAM/latest/UserGuide/access_iam-tags.html
10. Review the settings and click the ‘Create user’ button if everything is correct (figure #10)
11. Download the user security credentials by clicking on the ‘Download.csv’ button (figure #11)
Note: the .csv contains the AWS Access Key ID and the AWS Secret Access Key. Also once you click Close you will not be able to see or download the credentials again.
12: Give the .csv file a recognisable name, create a folder to hold the file, and click the ‘Save’ button (figure #12)
13. Once the file is saved open it in a text editor or spreadsheet application such as Numbers (figure #13)
14. You can now go back to the AWS Web Console and click the ‘Close’ button to close the Add User window
Configure the AWS CLI App
1. Open the Terminal App if it’s not already open and, at the prompt, type in the command line aws configure (figure #14)
2. Select the ‘Return’ key to display the first entry field, AWS Access Key ID (figure #15)
3. Enter your AWS Access Key ID. In my example it’s AKIATVPL3PASBS5CWSNI and select the ‘Return’ key (figure #16)
Note: you can cut and paste from the .csv file into the Terminal App
4. The second entry field, Secret Access Key, is shown. Repeat step 3 with the Secret access key, in my example it’s ccKn1bp/0AbJyhhexbq2N4YHFUr4ck4WG1ZuzeIz and select the ‘Return’ key (figure #17)
5. Add your Default region name, mine is ap-southeast-2 and select the ‘Return’ key (figure #18)
6. Add your Default output format, in this case we will use ‘json’, and select the ‘Return’ key (figure #19)
7. Test the configuration by typing the following command line aws s3 ls at the prompt and selecting the ‘Return’ key (figure #20)
In the Terminal window we can see the S3 buckets created in AWS. In this example I have two s3 buckets s3360panos and s3threesixtypanos.
Note: we have connected with AWS (aws) go to S3 (s3) and provide a list (ls) all of the buckets that have been created.
8. Quit the Terminal App, reopen it, and type in the Command Line aws configure at the prompt. Now the data is automatically entered into the data fields and we are ready to go to the next stage (figure #21)
AWS CLI Profiles
When you configure the AWS CLI, it stores your credentials and configuration settings in a file on your computer. By default, these files are located in the following locations:
Credentials file:
~/.aws/credentials
(on Linux, macOS, or Unix) orC:\Users\<username>\.aws\credentials
(on Windows). This file stores your access keys (figure #22)Config file:
~/.aws/config
(on Linux, macOS, or Unix) orC:\Users\<username>\.aws\config
(on Windows). This file stores configuration settings such as the default region and output format (figure #23)
These files allow the AWS CLI to use your credentials and configuration settings without requiring you to enter them each time you run a command by creating a Profile.
Using profiles allows you to easily switch between different AWS accounts or roles, manage multiple sets of credentials, and specify different regions for various tasks, enhancing flexibility and security.
A good example of using a profile with the AWS CLI is when you manage multiple AWS accounts, such as personal and work accounts, or different environments like development, staging, and production.
Scenario:
Imagine you are a developer working on two projects:
A personal project hosted in your personal AWS account.
A work project hosted in your company's AWS account.
Configure Profiles:
You would create two profiles:
personal
andwork
.
aws configure --profile personal
aws configure --profile work
Switch Between Profiles:
To access all the S3 buckets in your personal account:
export AWS_PROFILE --profile personal
To access all the S3 buckets in your work account:
export AWS_PROFILE --profile work
Creating a basic Profile to Access AWS
Note: as it has been quite a while since this tutorial was created I’m not working on a different computer (Mac Studio) and OS (Sonoma) so my terminal is now running under -zsh rather than -bash. However this doesn’t affect any of the command prompts. (figure #24)
1. Enter the prompt ‘aws configure --profile [your profile name]’
Note: I’m going to use the profile name ‘awspano’ (figure #25)
2. Enter return until the configuration is complete (figure #26)
3. Open the Credentials and Config files to see the new profile just created. (figures 26 & 27)
This brings us to the end of Part 2: Configuration and we are ready to move onto Part 3: Upload where we will upload some files and look at other options open to us.
Summary
I hope you have enjoyed the tutorial and it has helped you to achieve the best possible project outcome. If it has please take a second to consider a donation so that I can continue to add more tutorials.