Skip to content

Latest commit

 

History

History
186 lines (143 loc) · 4.21 KB

README.md

File metadata and controls

186 lines (143 loc) · 4.21 KB

Scalable WebSocket Server with Redis Pub/Sub

A scalable WebSocket server implementation using Redis Pub/Sub for message distribution across multiple server instances. This architecture allows for horizontal scaling via kubernetes' horizontal pod auto-scaler while maintaining real-time message delivery across all connected clients.

Architecture Overview

Architecture Diagram

Core Components

  1. WebSocket Server Layer

    • Handles client connections
    • Manages WebSocket lifecycle
    • Routes messages to appropriate handlers
  2. Redis Manager (Singleton)

    • Manages Redis connections
    • Handles Pub/Sub operations
    • Ensures single Redis connection pool
  3. Subscription Service

    • Tracks active WebSocket connections
    • Manages room subscriptions
    • Handles message broadcasting
  4. Message Flow

sequenceDiagram
    Client->>WebSocket Server: Connect
    WebSocket Server->>Subscription Service: Register Client
    Client->>WebSocket Server: Subscribe to Room
    WebSocket Server->>Redis: Subscribe to Channel
    Client->>WebSocket Server: Send Message
    WebSocket Server->>Redis: Publish Message
    Redis->>WebSocket Server: Broadcast to Subscribers
    WebSocket Server->>Client: Deliver Message
Loading

Features

  • Real-time bidirectional communication
  • Horizontally scalable
  • Redis-based message persistence
  • Automatic reconnection handling
  • Multiple room support
  • TypeScript for type safety

Installation

  1. Clone the repository
git clone https://github.com/omkargade04/Scalable-Websocket-Server.git
cd Scalable-Websocket-Server
  1. Install dependencies
npm install
  1. Configure Redis
cd docker
docker-compose up -d
  1. Start the server
npm start

Project Structure

src/
├── managers/
│   └── RedisManager.ts     # Redis connection management
├── services/
│   ├── WebSocketService.ts # WebSocket handling
│   └── SubService.ts       # Subscription management
├── types/
│   └── types.ts           # TypeScript interfaces
├── utils/
│   └── helper.ts         # Utility functions
└── index.ts               # Application entry point

Usage

Connect to WebSocket Server

const ws = new WebSocket('ws://localhost:8080');

Subscribe to a Room

ws.send(JSON.stringify({
    type: 'SUBSCRIBE',
    room: 'room1'
}));

Send Message to Room

ws.send(JSON.stringify({
    type: 'SEND_MESSAGE',
    roomId: 'room1',
    message: 'Hello, World!'
}));

Unsubscribe from Room

ws.send(JSON.stringify({
    type: 'UNSUBSCRIBE',
    room: 'room1'
}));

Message Types

Type Description Payload
SUBSCRIBE Join a room { room: string }
UNSUBSCRIBE Leave a room { room: string }
SEND_MESSAGE Send message to room { roomId: string, message: string }

Scaling

The application can be scaled horizontally by running multiple instances behind a load balancer. Redis Pub/Sub ensures message delivery across all instances.

# Start multiple instances
PORT=8080 npm start
PORT=8081 npm start
PORT=8082 npm start

Development

Running in Development Mode

npm run dev

Building

npm run build

API Documentation

RedisManager

class RedisManager {
    // Get singleton instance
    static getInstance(): RedisManager;
    
    // Connect to Redis
    connect(): Promise<void>;
    
    // Publish message to channel
    publish(channel: string, message: string): Promise<void>;
    
    // Subscribe to channel
    subscribe(channel: string, callback: (message: string) => void): Promise<void>;

    // Unsubscribe to channel
    unsubscribe(channel: string) => void): Promise<void>;
}

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details