Javascript 使用集群在单独的线程中运行节点js CPU密集型代码?

Javascript 使用集群在单独的线程中运行节点js CPU密集型代码?,javascript,node.js,multithreading,cluster-computing,Javascript,Node.js,Multithreading,Cluster Computing,我有一个类,它的函数被证明是相当CPU密集型的,我正在尝试确定将其分离到另一个线程的最佳方法。我使用下面的代码来测试这一点,但我不确定这是否是实现这一点的最佳方法。最终,我希望有一个具有CPU密集型函数的类,并且能够选择在单独的线程上运行它 我的工作代码: var cluster = require('cluster') if (!cluster.isMaster) { // cpuHog is only called inside the child process cons

我有一个类,它的函数被证明是相当CPU密集型的,我正在尝试确定将其分离到另一个线程的最佳方法。我使用下面的代码来测试这一点,但我不确定这是否是实现这一点的最佳方法。最终,我希望有一个具有CPU密集型函数的类,并且能够选择在单独的线程上运行它

我的工作代码:

var cluster = require('cluster')

if (!cluster.isMaster) { // cpuHog is only called inside the child process    
    console.log(`Worker is listening on pid:${process.pid}`);
    process.on('message', (input) => {
        console.log(`Request receved for input ${input}`)
        cpuHog(input).then(output => process.send(output))
    })
    return; // exit if child
}

function cpuHog(input){
    return new Promise( (resolve)=> { setTimeout(()=> {resolve(input*input)},2000) }) 
}

function createSeparateThread(input){
    return new Promise((resolve,reject) => {
        var worker = cluster.fork()
        worker.on('message', resolve);
        worker.send(input)
    })
}

var input = 5
createSeparateThread(input).then( output => console.log(`Received result is ${output}`))
// My normal async node js code...
因此,如果上面的代码没有问题,我如何将其转换为类实例

var myClass = new MyClass()
// this should start a new thread
myClass.createSeparateThread(5)

我觉得不错。不要忘记
.catch()
可能出现的错误