要实现不同端口上的多个无服务器进程,可以使用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;。
                    上一篇:不同端口的重复爬取目标