Is a JavaScript runtime built on Chrome`s V8 JavaScript engine

Node.js for Mac

Node.js for Mac

  -  85.12 MB  -  Open Source
  • Latest Version

    Node.js 23.4.0 LATEST

  • Review by

    Daniel Leblanc

  • Operating System

    macOS 10.12 Sierra or later

  • User Rating

    Click to vote
  • Author / Product

    Node.js Foundation / External Link

  • Filename

    node-v23.4.0.pkg

  • MD5 Checksum

    cafb5d6ce9eca3d3e09b78edafd8c571

As an asynchronous event-driven JavaScript runtime, Node for Mac is designed to build scalable network applications. In the following "hello world" example, many connections can be handled concurrently. Upon each connection, the callback is fired, but if there is no work to be done, Node for macOS will sleep.

This is in contrast to today's more common concurrency model where OS threads are employed. Thread-based networking is relatively inefficient and very difficult to use. Furthermore, users of Nodejs are free from worries of dead-locking the process, since there are no locks. Almost no function in the app directly performs I/O, so the process never blocks. Because nothing blocks, scalable systems are very reasonable to develop in Node.

Node.js is similar in design to and influenced by, systems like Ruby's Event Machine or Python's Twisted. It takes the event model a bit further. It presents an event loop as a runtime construct instead of a library. In other systems, there is always a blocking call to start the event-loop. Typically behavior is defined through callbacks at the beginning of a script and at the end starts a server through a blocking call like EventMachine::run(). In Node js, there is no such start-the-event-loop call. It simply enters the event loop after executing the input script. The tool exits the event loop when there are no more callbacks to perform. This behavior is like browser JavaScript — the event loop is hidden from the user.

HTTP is a first-class citizen in Nodejs, designed with streaming and low latency in mind. This makes Node js well suited for the foundation of a web library or framework.

Just because Nodejs is designed without threads, doesn't mean you cannot take advantage of multiple cores in your environment. Child processes can be spawned by using child_process.fork() API, and are designed to be easy to communicate with. Built upon that same interface is the cluster module, which allows you to share sockets between processes to enable load balancing over your cores.

Also Available: Download Node.js for Windows

  • Node.js 23.4.0 Screenshots

    The images below have been resized. Click on them to view the screenshots in full size.

    Node.js 23.4.0 Screenshot 1
  • Node.js 23.4.0 Screenshot 2
  • Node.js 23.4.0 Screenshot 3
  • Node.js 23.4.0 Screenshot 4

What's new in this version:

- (SEMVER-MINOR) cli: implement --trace-env and --trace-env-[js|native]-stack
- doc: add LJHarb to collaborators
- (SEMVER-MINOR) net: add BlockList.isBlockList(value)
- (SEMVER-MINOR) net: support blockList in net.connect
- (SEMVER-MINOR) net: support blockList in net.Server
- (SEMVER-MINOR) net: add SocketAddress.parse
- (SEMVER-MINOR) process: deprecate features.{ipv6,uv} and features.tls_*
- (SEMVER-MINOR) sqlite: unflag node:sqlite module
- (SEMVER-MINOR) sqlite: add StatementSync.prototype.iterate method