An API Monitoring Scaffold Solution

I HATE on-call. That's why when I decided to start doing my own side-hustle, I wanted to make sure there were no 4 AM wake-ups unless necessary. I have designed a very simple and cheap process for monitoring websites that uses AWS services.

An API Monitoring Scaffold Solution

This solution runs a simple Lambda topic that checks the availability of an endpoint. The Lambda automatically manages CloudWatch Alarms for each configured site. If the threshold is breached, the SNS Topic is alerted and you are sent a message via either SMS or Email (whichever you have configured).

Getting Up and Running

I’ve created a simple solution to enable this monitoring for each Hosted Zone. We go into Route 53 and add the following comments to each of our Hosted Zones:

e.g. on;www;24x7
  • ON_OR_OFF: lowercase “on” or “off”. If set to “on”, the script will monitor your website.
  • SUBDOMAIN: the subdomain to monitor. E.g. if my subdomain is www and my Hosted Zone is, then it will check the URL
  • AVAILABILITY_HOURS: Not yet implemented.

Installing the Monitoring System

  1. Install Terraform.
  2. Run the following commands:
git clone
cd aws-www-monitoring/
terraform init
terraform apply
  1. Create a subscription in the SNS Topic that should have been created (default: web_monitoring).

That is it, you’re all done! You will receive an initial ALARM text but within five minutes you should receive the OK text (unless of course your site is down).

Use Cases

In most circumstances for simple websites, I would use Route 53 Health Checks. However, I designed this solution as a simple project that would enable someone to fork and get started on some complex monitoring. There are some websites that need to perform specific checks on APIs and this Lambda-based solution provides the framework for that to occur.

If you have any questions or problems, or you'd like to offer some suggestions for future content, please contact me on Twitter @stophammotime.