栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Node.js,多线程和Socket.io

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Node.js,多线程和Socket.io

实际上,您的代码应如下所示:

var cluster = require('cluster');var http = require('http');var numCPUs = require('os').cpus().length;if (cluster.isMaster) {  // Fork workers.  for (var i = 0; i < numCPUs; i++) {    cluster.fork();  }} else {  var sio = require('socket.io')  , RedisStore = sio.RedisStore  , io = sio.listen(8080, options);  // Somehow pass this information to the workers  io.set('store', new RedisStore);  // Do the work here  io.sockets.on('connection', function (socket) {    socket.on('chat', function (data) {      socket.broadcast.emit('chat', data);    })  });}

另一个选择是打开Socket.IO以侦听多个端口,并具有类似HAProxy负载平衡之类的东西。无论如何,您都知道最重要的事情:使用RedisStore在流程外扩展!

资源:

http://nodejs.org/docs/latest/api/cluster.html
http://delicious.com/alessioaw/socket.io



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/417906.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号