Where to Start with AWS as a Developer

Hi! šŸ‘‹ This article has been turned into a talk! Check out the latest version of the slides. šŸŽ‰

AWS (Amazon Web Services) is massive. At the time Iā€™m writing this, there are 175 different services on AWS! This surface area is bigger than most things you might try to learn as a developer. So where do you get started? How do you start chipping away at this complex elephant, but do it in a way thatā€™s practical?

Iā€™m a few months in to my AWS journey and I wanted to share what concepts and resources Iā€™ve found helpful so far. I resisted getting into AWS for a while because of its complexity. Any time I would log into AWS, my eyes would glaze over and my head would spin.

I realized, though, that ignoring AWS for much longer will be to my detriment. AWS is dominating the hundred billion dollar cloud infrastructure and computing market:

AWS Public Cloud Share graph by Statista

Source

Because of this, AWS certifications are in very high demand. I decided a few months ago that itā€™s time for me to step up and at least get the Cloud Practitioner certification, and probably others like the Solutions Architect Associate.

Big AWS Concepts for Developers

Letā€™s lay down a couple of definitions to help you as you progress in your AWS education.

First, what are cloud computing and cloud infrastructure? In short, this means that instead of you having to physically set up servers and networks in your garage or at your company, you ā€œrentā€ these from Amazon. Everything you might want to do to run a website ā€” the hardware that runs the server, the database, the storage that holds the frontend and static files, and the domain name configuration ā€” can be done using AWSā€™s networking and computing resources.

Why does this matter? The main reason is scalability: the ability to grow based on demand. AWS alleviates both the cost and logistics of scaling a service or business. Imagine youā€™re running an online store for dog toys on a single server in your garage (you probably bought it on eBay). Suddenly, Thoughts of Dog tweets about your store and your traffic spikes by twenty times as millions of people try to buy your bespoke artisan chew toys. Whatā€™s going to happen? Most likely your server will crash due to that much demand. Youā€™re frantically searching eBay for another server and some networking equipment, but it will likely cost you a couple thousand bucks and several days to upgrade your server or add additional servers to your network. Ouch! (Incidentally, a show that demonstrates this dilemma perfectly is Halt and Catch Fire, which is about startups in the 80s.)

Services like AWS, Azure, and Google Cloud Platform came along and revolutionized the industry. Now instead of needing to buy a brand new server, you can click a button and immediately grow your infrastructure. Even better, you can automatically grow and shrink your infrastructure as demand for your site or service fluctuates. This helps keeps costs more predictable and spreads them out over time instead of all at once with big hardware purchases.

Key AWS Services for Developers

When approaching AWS as a developer, there are a few of the core services that youā€™ll likely encounter right away, so hereā€™s a quick overview of those:

These are the core services I would focus on as a developer getting started with AWS. There are many, many more services relevant to developers, but getting a handle on the basics of these will get you quite a long way.

AWS Pitfalls for Developers

The two main pitfalls you might run into as you learn AWS (other than its sheer complexity) are billing and identity and access management (IAM).

AWS is not free to use, though there is a free tier and some services are free. Usually these costs are minor for short periods of time, but beware: if you run through a tutorial and then forget to clean up after yourself, you might face a big bill at the end of the month! Be sure to know what costs youā€™re incurring as you do tutorials and try to shut down and delete anything you donā€™t need when youā€™re finished. AWS also lets you create billing alerts that will email you when youā€™ve hit a threshold. Hereā€™s a great egghead collection on AWS cost management that will help a lot.

The other really sticky area in AWS is security. Identity and Access Management (IAM) in AWS is extremely complex. There are many layers of permissions for each service, user, and group. Most tutorials will help you navigate the basic set up that you will need to get things done. Be careful that youā€™re not leaving yourself open to big vulnerabilities as you learn. Not only does that open the door to data theft, but it could also result in huge bills if someone gets a hold of your root account. This doc is kind of scary, but youā€™re going to want to get familiar with security best practices in AWS little by little. At the very least, secure your root account and enable MFA.

For the sake of both billing and IAM, you will likely want to avoid using your employerā€™s AWS account to learn. If your job is the motivation for learning AWS, work with your company on creating a sandboxed account with a given budget.

Overview of AWS Certifications

While not all certifications in tech are created equal, AWS certifications are extremely valuable. Theyā€™re designed to minimize false positives and fairly rigorous, so employers know they can use them as a solid benchmark of knowledge. This means they can add some zeroes to your paycheck and set you apart from the average developer.

There are many different AWS certifications, so letā€™s break down what the options are.

The Cloud Practitioner exam is considered a Foundational exam recommended for people with 6 months of fundamental AWS knowledge. Itā€™s high-level and not super technical, but gets your feet with AWS.

From there, there are three Associate level exams, recommended for people with 1 year of experience solving problems and implementing solutions using AWS. These exams have broad scope but shallow depth and break into three paths: Architect, Operations, and Developer. The three exams are:

From there, there are two Professional certifications, recommended for people with 2 years of comprehensive experience designing, operating, and troubleshooting solutions using AWS. These exams have broader scope and are quite deep. The Architect path remains, but Developer and Operations combine into DevOps. The two exams are:

There are also six Specialty exams, which are very narrow in scope but very deep:

I decided to get some of these certifications as a way to guarantee that I will actually set aside the time to learn some AWS and have something to show for it. My plan is to get the Cloud Practicioner and then the Solutions Architect Associate. Why not the Developer Associate first? Well, my understanding is that the Solutions Architect Associate is more comphrensive than the Developer Associate, and thus itā€™s easier to get the Developer Associate after getting the Solutions Architect Associate. It also sets you up to get the Solutions Architect Professional, which is extremely difficult and highly coveted (and thus should come with a big pay raise!). The SA-P requires the SA-A, so it makes sense to go that route. Iā€™ll update this article when Iā€™ve got some results.

AWS Resources for Developers

There are boatloads of resources for learning AWS out there. Some are geared towards infrastructure and networking folks, some are geared towards database admins, some for security teams, and others towards developers. Here are the key resources Iā€™ve been using and a variety of others Iā€™ve found useful.

My Essential AWS Resources

Iā€™ve found myself relying pretty heavily on these resources in my own AWS journey:

Other Helpful AWS Resources for Devs

Here are some other very helpful resources Iā€™ve found for learning AWS. I donā€™t refer to these as regularly, but thatā€™s partially because my focus is on the Cloud Practicioner exam right now.

Conclusion

In this article, weā€™ve talked about how to get started learning AWS as a developer. Weā€™ve covered big AWS concepts, key AWS services for devs, common pitfalls, and a whole host of resources. I hope youā€™ve found it all helpful! Iā€™m still a newbie (hooray for learning in public!), so reach out to me on Twitter if Iā€™ve missed your favorite resource or if youā€™ve found anything particularly useful.

If youā€™re trying to level up your developer career through writing and speaking or hoping to become a developer advocate, hop on my email newsletter below and check out my books Getting Started in Developer Relations and Guide to Tiny Experiments: A Simple Framework to Finish What You Start.

See you next time!

Project list gathering dust? šŸ‘€

Drop me a line below so I can send you the Tiny Experiments framework and worksheet. You'll also join over 2100 other devs and dev advocates on the Developer Microskills newsletter.