ChatApp-2.0 is a real-time chat application built with modern technologies to deliver fast and scalable messaging features. The frontend is built on Next.js (v14) with TypeScript, utilizing OAuth (Google) for authentication, while the backend architecture is powered by TypeScript, Express, Socket.io for real-time WebSocket connections, Redis for PUB-SUB messaging, Kafka for message queuing, and PostgreSQL for data persistence.
- Real-time messaging: Enables real-time communication using WebSockets.
- Private rooms: Users can create private rooms, visible only to the creator.
- Public rooms: Open rooms visible to all users.
- OAuth (Google) Authentication: Secure login with Google.
- Scalable architecture: The backend leverages Redis for PUB-SUB communication across WebSocket servers, Kafka for message queuing, and PostgreSQL for database storage.
- Dockerized Services: Zookeeper, Kafka, and Redis are containerized using Docker.
- Next.js v14
- TypeScript
- OAuth (Google) for Authentication
- Socket.io: WebSocket connections for real-time messaging.
- Redis: PUB-SUB model for communication between WebSocket servers.
- Kafka: Message queue to manage and offload messages to the database.
- PostgreSQL: Relational database for message storage.
- Docker: Containers for Redis, Kafka, and Zookeeper.
- Docker: Make sure Docker is installed and running on your machine.
- Node.js: Ensure Node.js is installed (v16 or higher recommended).
- PostgreSQL: Running as the main database (via Docker or locally).
git clone https://github.com/ar-rana/ChatApp-2.0.git
cd ChatApp-2.0
GOOGLECLIENT_ID
GOOGLECLIENT_SECRET
cd server
npm install
cd client
npm install
docker-compose up
npm run dev
npm run dev
During this project I learned to integrate a pub-sub model and a messaging queue using redis and kafka, and implimented real time messaging using websockets and created a scalable chat app. During this project I also learned typescript and how to impliment OAuth in NextJs.