-
Notifications
You must be signed in to change notification settings - Fork 7.3k
FAQ
http://logs.nodejs.org/node.js/
- When referring to the software or the project in general, it's Node.js or simply Node. It is a proper noun, so capitalize it. The
.js
appears with the first use, to disambiguate from other things called "Node", andNode
(without the .js) afterwards. One way to think of this is thatNode.js
is the full name, andNode
is the more familiar first name. - When referring specifically to the binary executable, it's always
node
, lower-case to match the binary's name itself. - When referring to the libs that are included with the binary, as opposed to the libs published by Node users in The npm Registry, it's
node-core
ornode core
. (See node core vs userland.) - "npm" is always lowercase, even when it appears at the start of a sentence, unless used in a context where all-caps are used (such as the title of a man page.)
- "Node.js" is pronounced either "node dot jay ess", or "node jay ess", or "node point javascript".
- "npm" is pronounced "en pee em", spelled out.
Odd versions are unstable, even versions are stable. v0.2 and v0.4 are even/stable. v0.3 and v0.5 are odd/unstable. The current stable series is v0.10.x. The next stable series will be v0.12.x. The stable branch takes bug fixes only - it does not change the JavaScript API, add-on API, nor ABI (you don't have to rebuild modules after upgrading node with-in a stable branch).
Currently, by default v8 has a memory limit of 512mb on 32-bit systems, and 1gb on 64-bit systems. The limit can be raised by setting --max_old_space_size
to a maximum of ~1024 (~1 GiB) (32-bit) and ~1741 (~1.7GiB) (64-bit), but it is recommended that you split your single process into several workers if you are hitting memory limits.
Leap seconds are seconds added or removed from UTC (Coordinated Universal Time) to keep it in sync with the Earth's rotation. If leap seconds were not added or removed, then UTC would drift from TAI. You can read much more about leap seconds on Wikipedia.
Because they are based on astronomical observations, leap seconds are scheduled and not predicted, or predictable. One has been scheduled for June 30th, 2015. What this means practically is that 23:59:59 will be followed by 23:59:60 before going on to 00:00:00. Leap seconds can be added (positive) or removed (negative). A negative leap second would mean that 23:59:58 would be followed by 00:00:00.
There have been problems caused by software not managing this second properly. Note also that depending on the specific implementation and time sychronization mechanisms used, a particular system may not actually "see" the leap second, but it will occur as a regular one second time correction at a later time.
As to how this affects node.js applications, as specified by ECMA-262, JavaScript and thus node.js, explicitly ignore leap seconds when calculating the difference, in seconds, between two dates. In any event, it wouldn't be possible to take those into account without a historical table, and taking deltas more than 6 months in the future is impossible as the schedule is not known.
For example, the following example code ( counting the number of seconds since Midnight, Jan 1st, 1970 GMT) does not include leap seconds.
var d0 = new Date(0);
var d1 = new Date(); // right now.
console.log('Unix time started',new Number((d1-d0)/1000).toLocaleString(),'seconds ago');