IAM roles allow you to grant privileges to IAM resources. 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/b6c8a/b6c8a5990001f21e908f17b51ab56b5490ca2a6e" alt=""
Now select the AWS service that you would like to grant the role to and choose Next: Permissions. I selected EC2 service as I’m going to grant role to an EC2 Instance.
data:image/s3,"s3://crabby-images/e5b69/e5b69e0a01371be35b0c3313cb36de49922b0427" alt=""
Now choose the policy that you would like to attach to the role. I want my EC2 Instance to be able to have S3 access. Hence I selected the AmazonS3FullAccess. Choose Next: Tags to add tags to the role.
data:image/s3,"s3://crabby-images/05e03/05e039c09cf6e1317ab9b27833aa8537f7271558" alt=""
Adding tags to any AWS service is optional. Choose Next:Review
data:image/s3,"s3://crabby-images/d8761/d8761cc2f4d2b170161eea3f6e6b32a27fcee676" 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/d17fb/d17fb5b8559858d30bdff6ee8247d0a222d36ab4" 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/f531f/f531f58f1247134e5fed1600396cbb6fa28bf0cc" alt=""
Select the 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/c015c/c015c577ed01362c14709cfcc4a1813715d1f24c" 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.