data:image/s3,"s3://crabby-images/03149/03149057c1996fc8feb6d172cd82f1d142ed949f" alt=""
In this walkthrough, we’ll be creating an S3 bucket in Amazon Web Services (AWS) using Terraform. This is a pretty straightforward walkthrough but you will change a bit of information in your .tf
files.
Prerequisites
AWS account
Terraform CLI
IDE (Pycharm or Cloud9 for example)
Step 1
Create a new IAM user with full S3 access. I’m going to grant my IAM user Administrator Access and S3 Full access.
data:image/s3,"s3://crabby-images/14191/14191c782b0f5734917511016212ede9132203c1" alt=""
Using the aws configure
command, input your new IAM user’s credentials.
data:image/s3,"s3://crabby-images/2e510/2e5100e93b3fed751e0a072440a7c532cf7219fb" alt=""
Step 2
Head over to Github and fork this repository. Once you’ve done that, git clone
the repo in your CLI.
data:image/s3,"s3://crabby-images/20a7b/20a7b063c12cf6821ca3e6f03ec8d8becfc793a2" alt=""
data:image/s3,"s3://crabby-images/51370/51370ca1abd8cc232367f9ceb981ae4e2b47cb64" alt=""
cd
into your repository.
data:image/s3,"s3://crabby-images/fb85a/fb85a70f8efa4a216b42daf4a68e162958baee85" alt=""
Head over to your variables.tf
file as we are going to make a few updates.
The first thing you’ll want to do is change the region of your AWS account. In this case, my account is in us-east-1
. Next, you’re going to change the name of your S3 bucket making sure it is globally unique.
data:image/s3,"s3://crabby-images/2a261/2a261e7c6224dfb32c54c3f56a779fbc1859ef8f" alt=""
There isn’t anything we have to change in the main.tf
file but let’s review a few main pieces of the code inside the file and what it’s going to do.
aws_s3_bucket_acl
: This part defines whether the bucket access will be private or not. In the AWS console, this is what it looks like.
data:image/s3,"s3://crabby-images/5ec9a/5ec9a5d1c246d1d9d2e5aeb5c6430478534b0429" alt=""
data:image/s3,"s3://crabby-images/a2dd3/a2dd333522f66b3babe6bcfbfb6073b1f34c8342" alt=""
aws_s3_bucket_public_access_block
: This line of code defines if the contents of the bucket can be publicly accessed or not. Setting this to “true” will block public access.
data:image/s3,"s3://crabby-images/9a850/9a85062d60cdf15921586c2c4d53b7a0252573ce" alt=""
data:image/s3,"s3://crabby-images/b6334/b633488946a09d05bb232db802f8ab5385abdb0f" alt=""
Step 3
Now that we’ve set up our configuration code, let’s initialize terraform with terraform init
data:image/s3,"s3://crabby-images/2ff37/2ff37b0da0b877a8618aad14877f4beac68386d9" alt=""
Let’s run our code with terraform apply
and watch our S3 bucket be deployed.
data:image/s3,"s3://crabby-images/23175/231752b88b2ef3d37ffa34aea1a5dd03c4afc4c4" alt=""
To confirm that your S3 bucket has been created, head over to the AWS management console.
data:image/s3,"s3://crabby-images/720ca/720ca1ee275cb2a0950eb2af9d8ec0fc51163a60" alt=""
Don’t forget to terraform destroy
your resources so you don’t incur any additional AWS charges outside of the free tier.
data:image/s3,"s3://crabby-images/6096d/6096d108975e6423152c2a2e229a043d94f61723" alt=""
data:image/s3,"s3://crabby-images/687ba/687ba2b307e952ea519b02ba8d1183736ab4bc3a" alt=""