Javascript nodejs群集模块-地址使用中错误

Javascript nodejs群集模块-地址使用中错误,javascript,node.js,express,cluster-computing,Javascript,Node.js,Express,Cluster Computing,我有一个express.js应用程序,每次有特定请求时,它都必须运行一个子进程(这里是:/compute/real-time)。将有用户创建的脚本来计算数据。因此,我使用节点集群模块创建一个工作人员池,并选择一个可以自由执行脚本的工作人员池。但我在创建集群的过程中遇到了困难。这是密码 clusterPool.js var cluster = require('cluster'); exports.setupCluster = function(){ console.log ("Setting u

我有一个express.js应用程序,每次有特定请求时,它都必须运行一个子进程(这里是:/compute/real-time)。将有用户创建的脚本来计算数据。因此,我使用节点集群模块创建一个工作人员池,并选择一个可以自由执行脚本的工作人员池。但我在创建集群的过程中遇到了困难。这是密码 clusterPool.js

var cluster = require('cluster');
exports.setupCluster = function(){
console.log ("Setting up cluster for bot processing " )
  if (cluster.isMaster){
    cluster.fork();   //one is good enough at the moment
  }
}
compute.js

var async = require('async');
var clusterPool = require('.././clusterPool')
//Start the cluster
clusterPool.setupCluster();
exports.computeRealTime = function(req,res){
    clusterPool.cluster.on("listening",function(worker){
        //....Do something with the worker
    })
}
webserver.js

// Include Express
var express = require('express');
var compute = require('.././compute');

// Create a new Express application
var app = express();

// Add a basic route – index page
app.get('/compute/real-time',compute.computeRealTime);

// Bind to a port
app.listen(3000);
以下是我面临的错误:

error:  code=EADDRINUSE, errno=EADDRINUSE, syscall=bind
error: Error: bind EADDRINUSE
at errnoException (net.js:884:11)
at net.js:1056:26
at Object.1:2 (cluster.js:587:5)
at handleResponse (cluster.js:171:41)
at respond (cluster.js:192:5)
at handleMessage (cluster.js:202:5)
at process.EventEmitter.emit (events.js:117:20)
at handleMessage (child_process.js:318:10)
at child_process.js:392:7
at process.handleConversion.net.Native.got (child_process.js:91:7)
请问这个问题有什么解决办法吗?
提前感谢

这是其中一种情况,当您的服务器代码遇到错误并且由于错误处理不当,我们收到异常,但端口仍然繁忙。因此,您需要清除保留该端口的应用程序。如果您使用的是linux,那么可以使用

lsof -i :3000
获取进程id并使用

kill -9 #processId

然后重新启动服务器。

谢谢@blunderboy的评论。但是,这里的同一个express应用程序正在使用端口3000。我正在尝试在同一个应用程序中运行一个内部集群,用于不同的请求处理。请给我一些提示。我也试着这么做,但谷歌现在似乎不是我的好朋友!