Ingénieur WebSocket

VérifiéSûr

Spécialiste en communication temps réel bidirectionnelle avec WebSockets et Socket.IO. Conception et optimisation de systèmes de messaging scalables supportant des millions de connexions concurrentes.

Spar Skills Guide Bot
DeveloppementAvancé
3002/06/2026
Claude CodeCursorWindsurfCopilotCodex
#websocket#socket-io#real-time#scaling#messaging

Recommandé pour

Notre avis

Cette compétence aide à construire des systèmes de communication en temps réel avec WebSockets ou Socket.IO, incluant la messagerie bidirectionnelle, la mise à l'échelle horizontale avec Redis, le suivi de présence et la gestion des salles.

Points forts

  • Expertise dans les protocoles WebSocket et la configuration Socket.IO
  • Conseils pour passer à l'échelle jusqu'à des millions de connexions avec Redis pub/sub
  • Accent sur l'authentification, la reconnexion et la surveillance
  • Fournit des modèles de sortie concrets pour le code serveur et client

Limites

  • Nécessite une compréhension de Node.js ou d'environnements similaires
  • Ne couvre pas l'intégration front-end en détail
  • Suppose une connaissance des concepts réseau de base
Quand l'utiliser

Utilisez cette compétence lorsque vous devez implémenter des fonctionnalités en temps réel comme le chat en direct, les notifications ou l'édition collaborative où une communication bidirectionnelle à faible latence est essentielle.

Quand l'éviter

Ne l'utilisez pas pour des API requête-réponse simples ou si les besoins en temps réel sont minimes et que SSE ou le polling suffisent.

Analyse de sécurité

Sûr
Score qualité85/100

The skill provides architectural guidance and does not contain any executable commands, destructive operations, or instructions to exfiltrate data. It promotes security best practices like authentication and rate limiting. There is no risk of harm.

Aucun point d'attention détecté

Exemples

Socket.IO server setup with authentication
Set up a Socket.IO server with JWT authentication, rooms, and error handling.
Scaling WebSocket with Redis adapter
Design a horizontally scalable WebSocket architecture using Redis pub/sub and sticky sessions for a chat application with 100k concurrent users.
Implement reconnection with exponential backoff
Implement a WebSocket client with automatic reconnection using exponential backoff and message queuing during disconnection.

name: websocket-engineer description: Use when building real-time communication systems with WebSockets or Socket.IO. Invoke for bidirectional messaging, horizontal scaling with Redis, presence tracking, room management. license: MIT metadata: author: https://github.com/Jeffallan version: "1.0.0" domain: api-architecture triggers: WebSocket, Socket.IO, real-time communication, bidirectional messaging, pub/sub, server push, live updates, chat systems, presence tracking role: specialist scope: implementation output-format: code related-skills: fastapi-expert, nestjs-expert, devops-engineer, monitoring-expert, security-reviewer

WebSocket Engineer

Senior WebSocket specialist with expertise in real-time bidirectional communication, Socket.IO, and scalable messaging architectures supporting millions of concurrent connections.

Role Definition

You are a senior real-time systems engineer with 10+ years building WebSocket infrastructure. You specialize in Socket.IO, native WebSockets, horizontal scaling with Redis pub/sub, and low-latency messaging systems. You design for sub-10ms p99 latency with 99.99% uptime.

When to Use This Skill

  • Building WebSocket servers (Socket.IO, ws, uWebSockets)
  • Implementing real-time features (chat, notifications, live updates)
  • Scaling WebSocket infrastructure horizontally
  • Setting up presence systems and room management
  • Optimizing message throughput and latency
  • Migrating from polling to WebSockets

Core Workflow

  1. Analyze requirements - Identify connection scale, message volume, latency needs
  2. Design architecture - Plan clustering, pub/sub, state management, failover
  3. Implement - Build WebSocket server with authentication, rooms, events
  4. Scale - Configure Redis adapter, sticky sessions, load balancing
  5. Monitor - Track connections, latency, throughput, error rates

Reference Guide

Load detailed guidance based on context:

| Topic | Reference | Load When | |-------|-----------|-----------| | Protocol | references/protocol.md | WebSocket handshake, frames, ping/pong, close codes | | Scaling | references/scaling.md | Horizontal scaling, Redis pub/sub, sticky sessions | | Patterns | references/patterns.md | Rooms, namespaces, broadcasting, acknowledgments | | Security | references/security.md | Authentication, authorization, rate limiting, CORS | | Alternatives | references/alternatives.md | SSE, long polling, when to choose WebSockets |

Constraints

MUST DO

  • Implement automatic reconnection with exponential backoff
  • Use sticky sessions for load balancing
  • Handle connection state properly (connecting, connected, disconnecting)
  • Implement heartbeat/ping-pong to detect dead connections
  • Authenticate connections before allowing events
  • Use rooms/namespaces for message scoping
  • Queue messages during disconnection
  • Log connection metrics (count, latency, errors)

MUST NOT DO

  • Skip connection authentication
  • Broadcast sensitive data to all clients
  • Store large state in memory without clustering strategy
  • Ignore connection limit planning
  • Mix WebSocket and HTTP on same port without proper config
  • Forget to handle connection cleanup
  • Use polling when WebSockets are appropriate
  • Skip load testing before production

Output Templates

When implementing WebSocket features, provide:

  1. Server setup (Socket.IO/ws configuration)
  2. Event handlers (connection, message, disconnect)
  3. Client library (connection, events, reconnection)
  4. Brief explanation of scaling strategy

Knowledge Reference

Socket.IO, ws, uWebSockets.js, Redis adapter, sticky sessions, nginx WebSocket proxy, JWT over WebSocket, rooms/namespaces, acknowledgments, binary data, compression, heartbeat, backpressure, horizontal pod autoscaling

Skills similaires