Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

The Socket.IO adapter based on Redis Streams, allowing to broadcast events between several Socket.IO servers.

License

NotificationsYou must be signed in to change notification settings

theknowledgepro/socket.io-redis-streams-adapter

 
 

Repository files navigation

The@socket.io/redis-streams-adapter package allows broadcasting packets between multiple Socket.IO servers.

Table of contents

Supported features

Featuresocket.io versionSupport
Socket management4.0.0✅ YES (since version0.1.0)
Inter-server communication4.1.0✅ YES (since version0.1.0)
Broadcast with acknowledgements4.5.0✅ YES (since version0.1.0)
Connection state recovery4.6.0✅ YES (since version0.1.0)

Installation

npm install @socket.io/redis-streams-adapter redis

Usage

With theredis package

import{createClient}from"redis";import{Server}from"socket.io";import{createAdapter}from"@socket.io/redis-streams-adapter";constredisClient=createClient({url:"redis://localhost:6379"});awaitredisClient.connect();constio=newServer({adapter:createAdapter(redisClient)});io.listen(3000);

With theredis package and a Redis cluster

import{createCluster}from"redis";import{Server}from"socket.io";import{createAdapter}from"@socket.io/redis-streams-adapter";constredisClient=createCluster({rootNodes:[{url:"redis://localhost:7000",},{url:"redis://localhost:7001",},{url:"redis://localhost:7002",},],});awaitredisClient.connect();constio=newServer({adapter:createAdapter(redisClient)});io.listen(3000);

With theioredis package

import{Redis}from"ioredis";import{Server}from"socket.io";import{createAdapter}from"@socket.io/redis-streams-adapter";constredisClient=newRedis();constio=newServer({adapter:createAdapter(redisClient)});io.listen(3000);

With theioredis package and a Redis cluster

import{Cluster}from"ioredis";import{Server}from"socket.io";import{createAdapter}from"@socket.io/redis-streams-adapter";constredisClient=newCluster([{host:"localhost",port:7000,},{host:"localhost",port:7001,},{host:"localhost",port:7002,},]);constio=newServer({adapter:createAdapter(redisClient)});io.listen(3000);

Options

NameDescriptionDefault value
streamNameThe name of the Redis stream.socket.io
maxLenThe maximum size of the stream. Almost exact trimming (~) is used.10_000
readCountThe number of elements to fetch per XREAD call.100
sessionKeyPrefixThe prefix of the key used to store the Socket.IO session, when the connection state recovery feature is enabled.sio:session:
heartbeatIntervalThe number of ms between two heartbeats.5_000
heartbeatTimeoutThe number of ms without heartbeat before we consider a node down.10_000

How it works

The adapter will use aRedis stream to forward events between the Socket.IO servers.

Notes:

  • a single stream is used for all namespaces
  • themaxLen option allows to limit the size of the stream
  • unlike the adapter based on Redis PUB/SUB mechanism, this adapter will properly handle any temporary disconnection to the Redis server and resume the stream
  • ifconnection state recovery is enabled, the sessions will be stored in Redis as a classic key/value pair

License

MIT

About

The Socket.IO adapter based on Redis Streams, allowing to broadcast events between several Socket.IO servers.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript100.0%

[8]ページ先頭

©2009-2025 Movatter.jp