要实现不同端口上的多个无服务器进程,可以使用Node.js的cluster模块。该模块允许创建一个主进程和多个工作进程,每个工作进程都可以监听不同的端口。
以下是一个代码示例:
const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
console.log(`主进程 ${process.pid} 正在运行`);
// 创建工作进程
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
// 监听工作进程的退出事件
cluster.on('exit', (worker, code, signal) => {
console.log(`工作进程 ${worker.process.pid} 已退出`);
});
} else {
// 每个工作进程监听不同的端口
const port = 3000 + cluster.worker.id;
http.createServer((req, res) => {
res.writeHead(200);
res.end(`工作进程 ${process.pid} 在端口 ${port} 上运行`);
}).listen(port);
console.log(`工作进程 ${process.pid} 在端口 ${port} 上启动`);
}
上述代码创建了一个主进程和与CPU核心数量相等的工作进程。每个工作进程监听一个不同的端口(从3001开始递增),并返回一个包含工作进程ID和端口号的HTTP响应。主进程负责创建工作进程,并处理工作进程的退出事件。
要运行该示例,保存为server.js
文件,然后在终端中运行node server.js
命令。主进程和每个工作进程会输出相应的日志信息。通过访问不同的端口,可以看到不同工作进程的响应。
注意:在Windows系统上,os.cpus().length
返回CPU核心的数量可能不准确。在这种情况下,可以手动指定工作进程的数量,例如const numCPUs = 4;
。
上一篇:不同端口的重复爬取目标