socket.io集群解決方案

關(guān)于socket.io的群集解決方案,官網(wǎng)中給出了3個示例代碼。除了負載均衡的軟件不同熄赡,其他的代碼其實都是一樣的,分別為:nginx,httpd, haproxy齿税。以下以nginx為例說明彼硫。官網(wǎng)給的demo基于docker,讓你可以直接運行偎窘。代碼結(jié)構(gòu)如下:

socket.io集群結(jié)構(gòu)
  • 首先代碼index.js中加入redis適配
var io = require('socket.io')(3000);
var redis = require('socket.io-redis');
io.adapter(redis({ host: 'localhost', port: 6379 }));

除此之外乌助,和單機下的代碼并無區(qū)別。由于客戶端可能連接到集群中不同的節(jié)點陌知,為了在集群中不同的節(jié)點之間傳遞消息他托,socket.io官方以redis的發(fā)布訂閱功能為基礎(chǔ)做了消息路由分發(fā):socket.io-redissocket.io-redis在節(jié)點向客戶端群發(fā)消息時會將該消息發(fā)布到redis的訂閱隊列中仆葡,讓其他節(jié)點能夠訂閱到該消息赏参,從而實現(xiàn)節(jié)點間消息推送。

  • nginx配置
worker_processes 4;
events {
  worker_connections 1024;
}
http {
  server {
    listen 80;
    location / {
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header Host $host;
      proxy_pass http://nodes;
      # enable WebSockets
      proxy_http_version 1.1;
      proxy_set_header Upgrade $http_upgrade;
      proxy_set_header Connection "upgrade";
    }
  }
  upstream nodes {
    # enable sticky session
    ip_hash;
    server server-john:3000;
    server server-paul:3000;
    server server-george:3000;
    server server-ringo:3000;
  }
}

該配置文件沿盅,在請求頭中加入 Upgrade 來支持 websocket
使用ip_hash保證同一個ip請求到固定的容器把篓。將請求分發(fā)給四個服務(wù):server-john,server-paul,server-george,server-ringo.

  • docker-compose配置
nginx:
  build: ./nginx
  links:
    - server-john
    - server-paul
    - server-george
    - server-ringo
  ports:
   - "3000:80"

server-john:
  build: ./server
  links:
    - redis
  expose:
    - "3000"
  environment:
    - NAME=John

server-paul:
  build: ./server
  links:
    - redis
  expose:
    - "3000"
  environment:
    - NAME=Paul

server-george:
  build: ./server
  links:
    - redis
  expose:
    - "3000"
  environment:
    - NAME=George

server-ringo:
  build: ./server
  links:
    - redis
  expose:
    - "3000"
  environment:
    - NAME=Ringo

redis:
  image: redis:alpine
  expose:
    - "6379"

該配置文件中,nginx依賴四個web服務(wù)腰涧,每個web服務(wù)都依賴redis韧掩。每個服務(wù)都暴露3000端口。environment環(huán)境變量用于標示當前的服務(wù)器名稱窖铡,以此來告訴客戶端請求被分發(fā)到哪臺服務(wù)器了疗锐。會在index.js以下的代碼中用到坊谁。

var serverName = process.env.NAME || 'Unknown';
  • 每個服務(wù)的docker配置
FROM mhart/alpine-node:6

# Create app directory
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app

# Install app dependencies
COPY package.json /usr/src/app/
RUN npm install

# Bundle app source
COPY . /usr/src/app

EXPOSE 3000
CMD [ "npm", "start" ]

該配置功能:拷貝package.json,安裝依賴滑臊,拷貝源文件口芍,啟動服務(wù)。

由于示例采用docker安裝雇卷,只要你的電腦中有安裝docker鬓椭,當我們下載完官方的代碼,直接在代碼根目錄下運行以下命令便可啟動服務(wù)進行測試关划。

$ docker-compose up -d
  • 注意

官網(wǎng)的 socket.io-redis庫只有在消息廣播(socket.broadcast.emit)的時候小染,才能生效。對于私發(fā)的消息祭玉,如果想在集群不同節(jié)點之間傳遞還是需要自己手動寫一個解決方案氧映,具體可以參考redis的發(fā)布訂閱功能在nodejs下的api春畔。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末脱货,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子律姨,更是在濱河造成了極大的恐慌振峻,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件择份,死亡現(xiàn)場離奇詭異扣孟,居然都是意外死亡,警方通過查閱死者的電腦和手機荣赶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門凤价,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拔创,你說我怎么就攤上這事利诺。” “怎么了剩燥?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵慢逾,是天一觀的道長。 經(jīng)常有香客問我灭红,道長侣滩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任变擒,我火速辦了婚禮君珠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘娇斑。我一直安慰自己策添,他們只是感情好澈段,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著舰攒,像睡著了一般败富。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上摩窃,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天兽叮,我揣著相機與錄音,去河邊找鬼猾愿。 笑死鹦聪,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蒂秘。 我是一名探鬼主播泽本,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼姻僧!你這毒婦竟也來了规丽?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤撇贺,失蹤者是張志新(化名)和其女友劉穎赌莺,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體松嘶,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡艘狭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了翠订。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片巢音。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖尽超,靈堂內(nèi)的尸體忽然破棺而出官撼,到底是詐尸還是另有隱情,我是刑警寧澤橙弱,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布歧寺,位于F島的核電站,受9級特大地震影響棘脐,放射性物質(zhì)發(fā)生泄漏斜筐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一蛀缝、第九天 我趴在偏房一處隱蔽的房頂上張望顷链。 院中可真熱鬧,春花似錦屈梁、人聲如沸嗤练。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽煞抬。三九已至霜大,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間革答,已是汗流浹背战坤。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留残拐,地道東北人途茫。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像溪食,于是被迫代替她去往敵國和親囊卜。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理错沃,服務(wù)發(fā)現(xiàn)栅组,斷路器,智...
    卡卡羅2017閱讀 134,654評論 18 139
  • 在項目中用到socket.io在WEB端做消息推送捎废,遂花了點時間看了socket.io實現(xiàn)笑窜,做個簡單分析致燥,如有錯漏...
    __七把刀__閱讀 29,812評論 20 54
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,930評論 2 89
  • 昨日出入一地方嫌蚤,曾經(jīng)免費的明朝龍腦橋辐益,居然被攔起來收費,看來有關(guān)部門真是和我一樣窮瘋脱吱≈钦看來,回家箱蝠,俺也致富续捂。把...
    隆昌的石頭閱讀 1,157評論 12 4
  • 騰起千里黃沙, 單槍催策快馬宦搬。 迎血斬敵駿馬下牙瓢, 更染絕色晚霞。 憑年少狂殺间校, 何懼戎馬生涯矾克。 金鼓連天,刀劍廝殺...
    忠君愛國好少年閱讀 290評論 0 0