This is really just to satisfy curiosity, and see if there's a better way to do this.
On my Windows 8 box, Node's process.env
object has a NUMBER_OF_PROCESSORS
property, on my Linux box it doesn't.
Obviously different platforms have different environment variables, that much is a given, but it seems like NUMBER_OF_PROCESSORS would be a useful thing to have regardless.
My quick fix for Linux was spawning a child process to run the nproc
command, but I'd like to avoid using a callback for simply getting the number of processors. Seems like there must be a simpler way.
What have other people done to solve this?
Open Device Manager (in the search box of the taskbar, type in "Device Manager", then select Open) Click on ">" to expand the Processors section. Count the number of entries to get the number of logical processors.
To get information about a system's CPU's, we will use the os. cpu() method that will return an array of objects with information about each CPU in it.
A node with 2 CPU-chips and 16 CPU-cores per CPU-chip can be used to carry out 32 tasks simultaneously. A job can be run on a single CPU-core, but if your code is modified to support parallel operations, a job may also run on multiple CPU-cores on one or more CPU-chips, and even on multiple nodes at one time.
Press Ctrl + Shift + Esc to open Task Manager. Select the Performance tab to see how many cores and logical processors your PC has.
It's built into node and called os.cpus()
Returns an array of objects containing information about each CPU/core installed: model, speed (in MHz), and times (an object containing the number of milliseconds the CPU/core spent in: user, nice, sys, idle, and irq).
The length of this array is the number of "processors" in the system. Most systems only have one CPU, so that's the number of cores of that CPU.
See the code below:
const os = require('os') const cpuCount = os.cpus().length
var os = require('os'), cpuCount = os.cpus().length;
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With