Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/managervcf/tick-it
Microservices ticketing app build with Node, NextJS, MongoDB, Docker and Kubernetes.
https://github.com/managervcf/tick-it
docker docker-container javascript kubernetes kubernetes-cluster microservices mongodb nextjs nodejs typescript
Last synced: about 1 month ago
JSON representation
Microservices ticketing app build with Node, NextJS, MongoDB, Docker and Kubernetes.
- Host: GitHub
- URL: https://github.com/managervcf/tick-it
- Owner: managervcf
- Created: 2020-06-04T01:24:26.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-02-01T23:05:31.000Z (almost 2 years ago)
- Last Synced: 2024-08-10T10:04:08.302Z (5 months ago)
- Topics: docker, docker-container, javascript, kubernetes, kubernetes-cluster, microservices, mongodb, nextjs, nodejs, typescript
- Language: TypeScript
- Homepage:
- Size: 2.35 MB
- Stars: 17
- Watchers: 2
- Forks: 4
- Open Issues: 74
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# TickIt
## Overview
Ticket selling app built based on microservices architecture. This project focuses on the production ready back-end, very simple React front-end is made just for demonstration and testing purposes.
### Functionality
The goal of the app is to allow users to buy and sell concert tickets. For handling credit card payments the app uses Stripe API.
### Structure
The app consists of 7 different services designed to comminicate in an asynchronous fashion. Services are written in TypeScript, running on NodeJS and built with NextJS (front-end), Express and MongoDB (back-end) and NATS Streaming Server to communicate via events. Each service lives in its own Docker container, managed by Kubernetes. For routing the `ingress-nginx` controller is used. The app also uses Sendgrid as an email API provider.
All services include a shared library as a dependency, called `@tick-it/common`, where all crucial type definitions live. This shared library is also included in this repository as a submodule.
List of microservices:
- `client` - Service responsible for the front-end.
- `auth` - Service responsible for authentication.
- `tickets` - Service responsible tickets.
- `orders` - Service responsible for orders.
- `payments` - Service managing payments.
- `expiration` - Service handling an order expiration time.
- `emails` - Service sending email confirmations after order completion.## Development
To manage all the Docker containers inside the Kubernetes cluster and simplify development workflow the project uses Skaffold.
To run the app in development environment, make sure Docker, Kubernetes and Skaffold are installed on your local machine.
Before running the app environment variables inside the Kubernetes cluster must be set. Execute commands below to set these environment variables:
```bash
# kubectl create secret generic stripe-secret --from-literal=STRIPE_KEY=# kubectl create secret generic jwt-secret --from-literal=JWT_KEY=
# kubectl create secret generic sendgrid-api-key --from-literal=SENDGRID_API_KEY=
```Be sure to expose the ingress-nginx-controller with:
```bash
# kubectl expose deployment ingress-nginx-contoller --target-port=80 --type=NodePort -n kube-system
```Start the app with `skaffold dev`.