F23 Self Contained Change: Node.js 0.12

Jan Kurik jkurik at redhat.com
Tue Jun 23 23:37:41 UTC 2015


= Proposed Self Contained Change: Node.js 0.12 =
https://fedoraproject.org/wiki/Changes/NodeJS012

Change owner(s): T.C. Hollingsworth <tchollingsworth at gmail dot com>

Fedora 23 will be updated to Node.js 0.12, the latest release of the platform built on Chrome's JavaScript runtime for easily building fast, scalable network applications. 

== Detailed Description ==
Node.js has seen many changes between v0.10 and v0.12. There is a listing of changes documented on the wiki. Note that this release includes API updates that may require dependency updates. Following are some highlights:

* Streams 3
        The Streams implementation now works the way you thought it already should, without introducing any changes to the API. Basically this means no more getting stuck in "old mode", there are only streams that are flowing or not.
        Streams now support the use of cork and uncork mechanisms to prevent flushing writes out to the system if an application is going to be performing many writes in a row. There is an implicit uncork performed when you end a writable stream. 

* HTTP
        maxSockets are no longer limited to 5. The default is now set to Infinity with the developer and the operating system given control over how many simultaneous connections an application can keep open to a given host.
        Proper KeepAlive support means that sockets will stay open until they timeout at the configured time, are closed by the remote side, or the process exits. Developer's no longer have to make sure requests have been pipelined to keep the socket open, or use an alternative module to get that support.
        Developers can also now explicitly flushHeaders to ensure time to first byte is low and proxied connections are held open. 

* Cluster
        Now has two modes of operation, the new default is a round robin distribution mechanism where the master accepts new connections and distributes them to your workers. If you want you can still opt back into the old method where your workers are responsible for acception connections. 

* TLS
        We have the new TLSWrap mechanism under the hood, this eliminates quite a few of the hops back and forth between JavaScript and our C++ implementations.
        Added APIs for asynchronous SNI callbacks, OCSP stapling, and storage events. 

* Buffer
        We use a more accurate mechanism for allocating memory for buffers now, which means you'll see less overhead and impact from holding onto to small slices of Buffers. This reduces the amount of memory pressure on the system, which means GC runs are quicker, which means Node.js is on CPU less, and thus lower latency for your applications. 

* child_process
        spawnSync/execSync have been added to facilitate synchronous child processes, warning your node process won't make forward progress while waiting for the child to exit, caveat emptor! 

* Crypto
        Added APIs for loading custom engines for use with compiled in OpenSSL.
        More APIs support supplying the pass phrases.
        Added APIs for RSA public/private key encryption/decryption. 

* VM
        The module is now based on the Contextify module, which shares values from the sandbox to avoid missing changes inside the execution from appearing in the parent context.
        Initial support for ECMAScript Internationalization API 1.0 (ECMA-402)
        By default, Node.js v0.12.0 binaries are shipped with ECMA-402 support, but only for the English language. In other words, the ECMA-402 API is working as you would expect, but only data for the English language is included. You can find more info on how to include more languages in the Wiki. 

These are just some of the changes you can find in this release of v0.12, and it's thanks to the hard work of the community and the members of team curating Node.js.

We are also pleased to report that this release of Node.js has tests passing on all of our supported platforms. On the one hand, this seems obvious (what are tests for if not to verify before you release it?!), but this is actually the first release of Node.js that has operated under this constraint. Requiring that all tests pass before releasing Node.js marks an important development for the project, and is essential for building a solid path moving forward. 

== Scope ==
* Proposal owners:
  -- Update v8
  -- Update nodejs
  -- Rebuild all binary modules, apply patches as necessary
  -- Update npm 
* Other developers:
  -- Other Node.js packagers' attention may be required if the update causes issues for their packages. 
* Release engineering: N/A (not a System Wide Change) 
* Policies and guidelines:
  -- Some minor updates to the Node.js guidelines are planned, however they are just Nice To Have for the purposes of this specific change. 
* Trademark approval: N/A (not needed for this Change) 
-- 
Jan Kuřík
_______________________________________________
devel-announce mailing list
devel-announce at lists.fedoraproject.org
https://admin.fedoraproject.org/mailman/listinfo/devel-announce


More information about the devel mailing list