Skip to content

A template ("boilerplate") project for creating simple serverless web applications hosted in AWS.

Notifications You must be signed in to change notification settings

peabnuts123/aws-serverless-template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AWS Serverless Template

This is a template/boilerplate project for more simply creating web applications hosted in AWS. It uses a "Serverless" architecture which is to say that the API runs on-demand via AWS Lambda functions, instead of a long-running process hosted on a server somewhere that you have access to. This makes the entire project extremely cheap to host, even at high volumes of traffic.

Architecture

DB

The database used in this project is AWS DynamoDB. This is essentially a NoSQL database that contains free-form objects that can have whatever data they want in them. DynamoDB mixes this paradigm up by referring to each object in the DB as a "row" in a "table" so it can be somewhat confusing to work with. It also has a strong concept of a "primary key" (which every object/row must have) but (like all NoSQL implementations) can't really handle "foreign keys" / relational data beyond nesting related objects as a property on the parent.

DynamoDB is relatively easy to work with for simple projects, but mostly it was chosen for cost purposes. It costs nothing to host until you are storing gigabytes of JSON data and sending out hundreds of Gb per month (at which point you can probably afford to spend a few dollars a month on your "pet project"). Comparatively, even a simple relational database will cost you tens of dollars a month to run for no traffic (and a lot more for high traffic).

DynamoDB can't be easily mocked so when running the project locally, Localstack is used to spin up a compatible mock of DynamoDB (running on Docker).

API (src/api)

The API is written in TypeScript for performance reasons. JavaScript is very quick to start up, so "cold-boot" times are relatively low (a second or so). Each API endpoint exports a handler function for that particular endpoint. In AWS these functions are each deployed to their own Lambda and wired together using API Gateway. In local development, a simple express server is started which maps the endpoints to each handler function.

When deployed, the API is proxied behind CloudFront so that the API and the frontend client can be served from the same domain.

Frontend client (src/www)

The frontend is a "single-page app" written in React (actually, Next.js). This was mostly chosen as it is the current favourite in the frontend community. Working in React is the best way to find support and integrations with other packages and libraries, which can quickly outweigh benefits gained from using other frameworks. Next.js sets up a working project with sane defaults which makes it much easier to work with React. Next.js also pre-renders all pages on your site at deploy-time so it makes for a rather snappy site load. Nevertheless, you are welcome to entirely replace the frontend with the framework of your choosing, as it is a standalone component that has no dependencies on it.

The web client is hosted on S3, and served through CloudFront. CloudFront caches all the site's assets so, again, load-times should be relatively quick. The cache is not enabled for content pages (i.e. not javascript bundles etc.) so deployments to the site are live instantly.

CloudFront (src/app)

In a production environment, the entrypoint into the app is through a CloudFront Distribution. This proxies both the frontend client as well as the API, so both can be served on the same domain. CloudFront manages caching of specific resources to increase request performance of your application around the world.

CloudFront also contains a small amount of logic in the form of "CloudFront Functions". These are simple functions that transform requests to/from CloudFront. Currently there is only 1 function, whose job it is to rewrite requests to the frontend client to ensure the correct HTML page is served based on the user's request.

Development

This repository contains a fully-working demo application. The application isn't terribly complex so it should be relatively easy to rip out the content that is there and replace it with your own. This is how this repository is intended to be consumed. It is not a framework, it's a project template. The demo project is there to show you how things are supposed to hang together, so that you can build your own without having to research the full context yourself.

Running the project

Each project is its own self-contained "component". A guide for running / developing each component can be found in each respective README:

The project as-a-whole is designed to be able to run in a few ways:

  • Manually within each component, for debugging / developing (e.g. npm start)
  • With docker-compose, for developing services that depend on other components
    • e.g. if you're working on the frontend and just need a working API to be running, you can run the API and the DB in docker, and run the frontend manually
  • On cloud infrastructure i.e. AWS

Broadly speaking you will need the following things to run the project locally:

  • Node.js and npm
  • Docker

Deployment

Deployment of this project to an AWS environment is done in multiple steps:

  1. Use Terraform to provision the AWS infrastructure needed
  2. Build and deploy the code needed for each of the individual components (api, app, www)

Check the individual docs of each (Terraform, api, app, www) for instructions on how to do these steps in detail.

Backlog

  • launch.json for debugging various aspects in vscode

About

A template ("boilerplate") project for creating simple serverless web applications hosted in AWS.

Topics

Resources

Stars

Watchers

Forks