An application running on EC2 instance that needs access to S3 requires credentials. You can distribute credentials to the app during deployment but it is not a secure design and Amazon discourages distributing credentials. Instead, you can use roles to grant privileges to AWS resources. Roles do not have long term credentials making it secure.
To create a role, login to the AWS Management console and select IAM. In the IAM dashboard select Roles and choose Create role.
data:image/s3,"s3://crabby-images/cdf17/cdf17459fb77406b44c614f26937a6f9d0ecf9e7" alt=""
Now select the AWS service(EC2 in our scenario) that you would like to grant the role to and choose Next: Permissions.
data:image/s3,"s3://crabby-images/2b678/2b678e275c9d3fcd5502ae51625f36f3f51f3130" alt=""
Choose the policy that you would like to attach to the role. I want my EC2 Instance to be able to have full access to S3. Hence I selected the AmazonS3FullAccess. Choose Next: Tags to add tags to the role.
data:image/s3,"s3://crabby-images/87495/8749544da3657e3191a0f92b84c4d23e5d56b9cd" alt=""
Adding tags to any AWS service is optional. Choose Next:Review
data:image/s3,"s3://crabby-images/b2401/b24010bc88f77f5b35985aefd0744d9fa45a927c" alt=""
Enter a value for the Role name and choose Create role. I named my role as ec2-to-s3.
data:image/s3,"s3://crabby-images/dedc4/dedc42c6d03305bd057bc3488770e3530133423a" alt=""
On the services page, choose EC2 to open the EC2 dashboard and right click on the instance that you would like to attach the role to and choose Attach/Replace IAM Role under Instance Settings.
data:image/s3,"s3://crabby-images/cce8c/cce8c9c100238da11ca0bb700fbc9698fd051d92" alt=""
Select the ec2-to-s3 role that you have previously created and choose Apply.
data:image/s3,"s3://crabby-images/f1c56/f1c5676375adda9cf38869b726415cbef52ce8dd" alt=""
The ec2-to-s3 role has been attached to the EC2 Instance. With this role attached, the EC2 Instance now has full access to the S3 resources.
data:image/s3,"s3://crabby-images/0e30a/0e30a38d38c51408ceefb26234507a463f5d0b7f" alt=""
To test the functionality of the role, SSH into the EC2 instance and type the command aws s3 ls to list all the buckets in your Amazon account.