Blog

!

I am Wee Kiat, a Software Engineer based in Singapore.
I enjoy architecting elegant software solutions that solves real world problems.

Also, I enjoy photography.

Portfolio

Photography

PeerPrep

PeerPrep Background

PeerPrep is a Software Engineering project, the objective is to create a technical interview preparation platform with collaboration capability. Users are matched with a partner to solve the question provided by the platform. PeerPrep provides collaboration functionalites such as shared editor and video call.

Features

Collaboration

Real-time collaboration tools to help simulate live coding environment in preparation for technical interviews.

Partner Matching

Matching facilitated based on the selected difficulty level, with option to create private rooms for specific collaborations.

Horizontal Scaling

With Microservices Architecture, we can horizontally scale only the services that are underload.

Horizontal Pod Autoscaler Demo

Under the Hood

In this project, we adopted the Microservices architecture. Each service is built using Express.jsExpress.js. Our frontend portal is a ReactReact application using Next.jsNext.js and Chakra UIChakra UI. Depending on the service’s functionality, we used either PostgreSQLPostgreSQL or MongoDBMongoDB for the database. For matching and real-time functionalities, RabbitMQRabbitMQ and Web Sockets are used.

All of the services are consolidated under an NginxNginx API Gateway. They are deployed using DockerDocker containers with KubernetesKubernetes as the orchestrator. We have a pipeline with Github Actions that deploys it to AWS SuiteAWS Suite hosting — Elastic Container Registry, Elastic Kubernetes Service.

Kubernetes Architecture

Project Insights

This assignment was a great opprtunity to learn and try out different technologies. It was fun working with Nginx, Docker and Kubernetes for the first time. I remember learning about auth_request directive in Nginx and refactored the project’s authentication flow to make it more elegant and streamlined.

Porting all the services from Docker Compose to Kubernetes was challenging but it felt really fulfilling when I managed to incorporate functionalities like Horizontal Pod Autoscaling and Self-healing.


© Wee Kiat, Atwelfth 3.0