Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tomdoestech/chat-tutorial
https://github.com/tomdoestech/chat-tutorial
chat pubsub react realtime redis
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/tomdoestech/chat-tutorial
- Owner: TomDoesTech
- Created: 2023-08-22T06:07:21.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-08-29T11:32:37.000Z (over 1 year ago)
- Last Synced: 2024-04-17T06:07:23.639Z (9 months ago)
- Topics: chat, pubsub, react, realtime, redis
- Language: TypeScript
- Homepage: https://youtu.be/cfEqS1A5diM
- Size: 85 KB
- Stars: 19
- Watchers: 1
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Build and Deploy a Chat Application That Scales Horizontally with WebSockets and Upstash Redis
## Thank you to Upstash for sponsoring this video!
Upstash is a serverless data platform that provides serverless Redis, kafka & QStash.## Who is this video for?
1. Those who are already familiar with JavaScript/TypeScript## Features
1. Send and receive messages
1. Show current connection count## What will you learn?
1. Create realtime communications with WebSockets
1. Use Redis Pub/Sub to communicate across multiple instances
1. Use Redis to stop data (connection count/ messages)
1. Use Docker and docker-compose to containerize the application
1. Docker multi-stage builds
1. Use GitHub actions to automate CI/CD
1. Graceful shutdowns## What are we using?
1. Fastify - Backend
1. Websockets - Realtime
1. Next.js - Frontend
1. Tailwind & Shadcn UI - Styling
1. Redis - Pub/Sub
1. Docker/docker-compose - Containerization
1. GitHub actions - CI/CD
1. DigitalOcean - Host the backend
1. Vercel - Host the frontend## What will you need?
1. [Upstash account](https://upstash.com/)
1. [Node.js](https://nodejs.org/en)
1. [Docker & docker-compose](https://docs.docker.com/engine/install/)
1. An editor - [VSCode](https://code.visualstudio.com/)
1. [DigitalOcean](https://www.digitalocean.com/) account
1. [Vercel](https://vercel.com/) account
1. [Vercel CLI](https://vercel.com/docs/cli)
1. [GitHub](https://github.com) account## Video structure
1. Build backend
1. Dockerise backend
1. Deploy backend
1. Create DigitalOcean droplet
1. Configure droplet
1. Write github action
1. Build frontend
1. Deploy frontend## Debugging
### Websockets
1. Make sure you are using `wss://` and not `ws://` in production
2. Use debug mode in Caddy server
```
{
debug
}
```### Docker
1. List our running docker containers
```bash
docker ps
```
1. Stop a running container
```bash
docker stop
```1. Remove a container
```bash
docker rm
```1. List out networks
```bash
docker network ls
```1. Remove a network
```bash
docker network rm
```