Javascript 使用集群在单独的线程中运行节点js CPU密集型代码?
我有一个类,它的函数被证明是相当CPU密集型的,我正在尝试确定将其分离到另一个线程的最佳方法。我使用下面的代码来测试这一点,但我不确定这是否是实现这一点的最佳方法。最终,我希望有一个具有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
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()
可能出现的错误