Skip to content

michaelin-96/Baratheon

This branch is 2 commits behind Baratheonly/SDC-QnA:main.

Repository files navigation

Baratheonly System Design | Questions & Answers

Summary

Created a backend API microservice to provide the required data (Questions and Answers) for an existing e-commerce website with existing frontend legacy code. Made incremental improvements to improve web traffic throughput (RPS) and response time in order to handle normal web traffic loads. Utilized stress testing tools such as k6 and loader.io to determine improvements in performance metrics.

Improvements

Database Improvements

  • Built aggregate Postgres queries to help reduce database bottlenecking in query times
  • Added indexing to lookup columns in Postgres database to improve lookup times. Improved lookup times from seconds to milliseconds

Horizontal Scaling

  • Deployed 4 AWS EC2 server instances with load balancing server through NGINX, to increase web traffic throughput from 100 RPS to 2000 RPS while maintaining 60 ms average response time with 0% timeout (error) rate
  • Implemented Caching in NGINX to further improve response times. Able to reduce times from 60ms to 5ms for most commonly requested products.

Before (Through k6 local stress testing)
k6

After (loader.io cloud stress testing)
loader.io

Installation

Step 1: Install dependencies ~ npm install

Step 2: start server ~ npm run server-dev

Technologies Used

  • Setup and Configuration
    Git NPM

  • Back End Development: Node.js, Express.js, PostgreSQL
    NodeJS Express.js PostgreSQL

  • Server Testing: Loader.io, k6
    k6 Loader.io

  • Deployment & Load Balancing: AWS EC2, Ubuntu, NGINX
    AWS Ubuntu

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 98.3%
  • Shell 1.7%