gpt4 book ai didi

javascript - node.js 集群、redis、单线程和非阻塞 i/o 是如何工作的?

转载 作者:搜寻专家 更新时间:2023-10-31 23:50:58 27 4
gpt4 key购买 nike

我将尝试总结一下我最近学到的所有关于 Node 配置的知识。如果正确请确认。如果我搞砸了,请纠正我和其他人。

Node.js 是一个服务器。作为服务器,它可以接收来自客户端的请求。假设一段时间内有 200 个请求。

由于 node.js 是单线程,它可以通过一个单元/一个内核处理所有这些请求。

然而,node 也是事件非阻塞 i/o,这意味着有人可以请求 node.js API 中的某些方法,需要 1 分钟才能完成,而其他人可以请求另一种方法,也需要 1 分钟才能完成。两者可以同时处理,无需等待对方完成。

现在这听起来很棒,但如果我们协助 Node 服务器并让它作为代理将 200 个请求的那些任务分配给集群/工作人员,它甚至会更好。因此, Node 服务器成为客户端和工作人员之间的代理。就像项目经理:)

这样做的好处是,我们现在有 4 个核心处理这些请求,而不是一个核心处理 200 个请求,每个核心都是事件非阻塞 i/o(当然取决于服务器规范)。

那可能 super 快。不是吗?

这是问题/我想了解的内容:

如何让这些集群/worker 共享工作?

我的意思是,如果 50 个请求转移到核心 1,50 个请求转移到核心 2,依此类推,直到所有可用的核心都可用,如何将套接字发送到两个不同的内核? (socket.io)

集群如何与速率限制器一起运行?我的意思是,速率限制器将禁止试图发送垃圾邮件或其他内容的用户,但随后立即撤销对该用户的禁止,因为它进入了不同的集群。

我听说 Redis 应该对此提供帮助。但它非常令人困惑,redis 是一个 DB 不是吗?我正在使用 MongoDB,为什么我需要更多数据库?

我会在这里放一些代码,也许解决方案就在眼前:

var cluster = require('cluster');
var redis = require("socket.io-redis");

if(cluster.isMaster) {

var numWorkers = require('os').cpus().length;
console.log('Master cluster setting up ' + numWorkers + ' workers...');

for(var i = 0; i < numWorkers; i++) {
cluster.fork();
}

cluster.on('online', function(worker) {
console.log('Worker ' + worker.process.pid + ' is online');
});

cluster.on('exit', function(worker, code, signal) {
console.log('Worker ' + worker.process.pid + ' stopped with code: ' + code + ', and signal: ' + signal);
console.log('Starting a new worker');
cluster.fork();
});

cluster.fork();

} else {

// define main required variables
var express = require('express');
var app = express();
var cors = require('cors');
var server = require('http').createServer(app);
var io = require('socket.io')(server);
var mongojs = require('mongojs');
var db = mongojs("mongodb://user:pass*@ip:port/dbname", []);
var ObjectId = require('mongodb').ObjectID;
var CronJob = require('cron').CronJob;
var request = require('request');
var fcm = require('./routes/fcm');
var Excel = require('exceljs');
var fs = require('fs');
var path = require('path');
var rateLimit = require('express-rate-limit');

// define some global limiter against spammer
var limiter = new rateLimit({
windowMs: 10*60*1000, // 10 minutes
max: 100, // limit each IP to 100 requests per windowMs (11 is on load and more 100 later on)
delayMs: 0, // disable delaying - full speed until the max limit is reached
message: "Service is block for you, try again later"
});

// apply to all requests
app.use(limiter);

// allow cross origin to access my api
app.use(cors());

var bodyParser = require('body-parser');
app.use(bodyParser.json()); // support json encoded bodies
app.use(bodyParser.urlencoded({ extended: true })); // support encoded bodies
app.use(express.static(__dirname + '/src'));

// my own routes
require('./routes/sockets')(app, io, mongojs, db, ObjectId, CronJob, request, fcm);
require('./routes/userServer')(app, io, mongojs, db, ObjectId, CronJob, request, fcm, rateLimit);
require('./routes/ridesServer')(app, io, mongojs, db, ObjectId, CronJob, request);
require('./routes/offersServer')(app, io, mongojs, db, ObjectId, CronJob, request, rateLimit);
require('./routes/notificationsServer')(app, io, mongojs, db, ObjectId, CronJob, request);
require('./routes/scopeServer')(app, io, mongojs, db, ObjectId, CronJob, request, fcm);
require('./routes/excelServer')(app, io, mongojs, db, ObjectId, CronJob, request, fcm, Excel, fs, path);

// listen
server.listen("8080", function() {
console.log("Connected to db and listening on port 8080");
});

}

如何处理这些事情?

谢谢。

最佳答案

我已经找到了解决方案,这里是:

对于具有多个集群的 socket.io 执行此操作:

第 1 步: 在您的机器上安装 Redis:brew install redis

第 2 步:运行 Redis 服务器:redis-server(从 SHELL 中的新选项卡)。

第 3 步: 安装 Redis 依赖项:npm install redis --save

第 4 步:在定义 io 之后包含 Redis 适配器,如下所示:

var io = require('socket.io')(server);
var redis = require('socket.io-redis');
io.adapter(redis({ host: 'localhost', port: 6379 }));

你准备好了。

使用Redis的限速器请关注下一个NPM Repo

关于javascript - node.js 集群、redis、单线程和非阻塞 i/o 是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48616956/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com