This article reprinted from: many into translation the translator: dainiel link: http://www.zcfy.cc/article/2201, https://blog.risingstack.com/10-most-important-node-js-articles-2016
2016 has been an exciting year for Node.js developers. Take a look at this chart to see what I mean:
Looking back on node.js’s six years of existence, we can claim that our favorite framework has come of age — it’s being used by some of the biggest companies in almost every industry in the world.
The other good news is that Node.js has become the largest open source platform in history — with 15 million downloads per month and over 1 billion downloads per week to prove it. We have over 1,100 developers contributing to the Node.js open source platform, and as a result, contributions are at an all-time high.
ð Code and Learn #Node Developer Exchange will push @nodejs core contributors to 1100
Code and Learn is a Nodejs organization that runs NodeInteractive, which translates as the Node Developer Conference
Looking back at the year, we’ve selected 10 articles that you shouldn’t miss as you pass by. It’s all about node.js in 2016, both good and bad.
Let’s take a look!
1: How did I take down Node,Babel, and countless projects with 11 lines of code
Programmers are shocked!! We saw compile failures and installation failures, all caused by Azer Koculu pulling 250 modules of his own from NPM in March 2016 — bringing down countless components, including Node and Babel
Don’t offend programmers…
Koculu deleted its code because it had a widget called Kik — the same name as the messaging app — and because of that, Kik’s lawyers claimed infringement, and NPM simply removed his widget.
“It made me realize that NPM is someone’s private domain, where companies have more power than ordinary people, and I open source because the power belongs to the people.” -Azer Koculu
Translator note: The Power To The People is The common slogan, literal translation for “right belongs To The People” here, you can refer To The wiki (slogan) https://en.wikipedia.org/wiki/Power_to_thepeople
Azer has a component called left-pad that fills the left side of the string with zeros and Spaces. Unfortunately, a whole bunch of components depend on it.
Follow-up to The whole event can be viewed in The Register’s Great Article, where updates will be posted in time.
2: Facebook releases a new JavaScript package management tool in conjunction with Google
In October 2016, Facebook and Google released Yarn, a new JavaScript package management tool
Why are we doing this? Facebook’s workflow has a number of principled issues when it comes to integrating NPM
-
At Facebook, NPM really doesn’t work.
-
NPM reduces the efficiency of a company’s continuous integration workflow.
-
Checking all components in the warehouse is also inefficient.
-
NPM is too uncertain to change — yet Facebook engineers need a continuous and efficient system to keep their DevOps workflows running.
Rather than hack around NPM’s limitations, Facebook started from scratch and developed Yarn:
Translator’s Note: It’s actually making wheels
-
Yarn has an advantage over locally cached files.
-
Yarn can also parallelize certain operations, which makes the installation of new modules faster.
-
Yarn uses file locks and a sophisticated installation algorithm to ensure cross-terminal file structure consistency.
-
For security reasons, Yarn does not allow package developers to run the required third-party code during installation,
Yarn claims to developers who don’t work on Facebook that it can deliver significant performance commissions, but it still uses NPM’s registration mechanism, which is essentially a knockoff of the NPM client
You can read the full article on TechCrunch.
3: Debug Node.js using Chrome Developer Tools
Debugging support for Node.js was added to the Node.js trunk in May
Use the new debugging tools you need
-
nvm install node
-
Add the inspect parameter to run Node: Node –inspect index.js
-
You’ll get a file that starts with “Chrome-devTools ://..” URL at the beginning, open it
Learn all the features and details by reading the Great Tutorial from Paul Irish!
4: 100 servers +5 days = 500,000 users. How did I do that? Guess what?
Jonathan Zarra, creator of GoChat for Pokemon GO, reached a million users in five days. Zarra was struggling to pay the cost of the server (around $4,000 / month), yet the costs associated with maintaining a million active users were essential.
He never dreamed there would be so many users. He built the app as a star product, with an eye on its future scalability. But he didn’t succeed.
Zara has previously had discussions with VCS about the app’s growth and monetization. He also thought it would be good enough to build it as a star product.
He was wrong.
Because of its humble design, GoChat didn’t retain that many users and went out of business. The money is spent and the users are gone
Five days, 500,000 users on a $100 / month server
Unboxd’s CTO Erik Duindam has spent his life designing and building web platforms for countless active users.
Frustrated by the poor design and bad luck of Zarra’s GoChat, Erik decided to create his own. _GoSnaps: Instagram/Snapchat for Pokemon GO. _
Erik uses Node.js to develop a scalable star app that can easily handle 500,000 unique users in 24 hours
All the installation is on a $100 / month midsize Google cloud server, plus a (simplified) Google cloud storage service for storing images — and the performance is remarkable.
How did he do it? For technical details, please read below:
Read my “100 servers +5 days = 500,000 users, How did I do it, guess?” https://t.co/euP0OFJdZJ #startups #pokemongo #tech
— Erik Duindam (@ErikDuindam) July 18, 2016
5: Learn Node.js from 0 – Node Star Tutorial series
The Node Star tutorial series is designed to help new developers learn Node.js from scratch and deliver software products with it!
You can find it all below:
-
Learn Node.js from 0
-
The use of NPM
-
Understand asynchronous programming
-
Your first Node.js HTTP server
-
Node.js database tutorial
-
Node.js Request component tutorial
-
Node.js project structure tutorial
-
Use Passport. Js to implement Node.js authentication
-
Node.js unit testing tutorial
-
Debug node.js applications
-
Node.js security tutorial
-
Deploy node.js applications on PaaS
-
Monitor Node.js applications
6: Use RabbitMQ and AMQP to distribute work queues in Node.js
This tutorial will help you use RabbitMQ to coordinate the work between producers and consumers.
Unlike Redis, RabbitMQ’s sole purpose is to provide a reliable and scalable communication solution with features that are currently unavailable or difficult to implement on Redis.
RabbitMQ is a server that runs either locally or on some node on the network. A client can be one or both worker processes and consumers, and it uses the Advanced Communication Queuing Protocol (AMQP) to talk to the server.
You can read the full tutorial here
7: Node.js, TC-39, and components
James M. Snell, head of NODE.js technology at IBM, attended his first TC-39 conference in late September.
Why?
A JavaScript language feature, or component, defined by TC-39 has caused quite a bit of trouble for the Node.js core team.
James and Bradley Farias _(@bradleyMeck)_ have been trying to figure out how best to support ECMAScript components (ESM) in Node.js without causing more trouble and confusion than it’s worth
As it turns out, Node.js and TC-39 have very different ideas about components: what they are, how they are defined, and how they are loaded into memory and used. From the beginning, Node.js has had a fairly loose component system that originated in CommonJS.
Because of the complexity of the issues involved, a long talk with TC-39 seems to be the most effective way to facilitate it.
The full text discusses what they found and understood from the dialogue.
8: Questionnaire survey and results of Node.js developers
In the summer of 2016 we conducted a survey on Trace by RisingStack to find out how developers were using Node.js.
The results show that MongoDB, RabbitMQ, AWS, Jenkins, Docker, and Amazon Container Services are preferred for node.js application development, packaging, and distribution.
It also turns out that the main pain point for Node developers is debugging
You can read the full story here at Node.js survey results and charts.
9: The Node.js Foundation will adopt a new collaborative approach to ensure the management of Node security issues
The Node Foundation announced at the North American Node.js developer Conference that it will take over the Node.js security project, which was created by Adam Baldwin and previously managed by ^Lift.
As part of the Node.js Foundation, the Node.js Security Project will provide a unified process to explore and mine security vulnerabilities found in the Node.js component ecosystem. A group within the foundation is responsible for managing the projects.
The Node.js Foundation will take over the following from ^Lift:
-
Maintain access to ecosystem vulnerability mining;
-
Maintain a closed communication channel for auditing vulnerabilities;
-
Audit participants of non-public security mining groups;
-
Research and testing to promote the sustainability of safety data;
-
Hold and publish underlying vulnerability data while
-
Create data standards that tool developers can build on, while security and developers can add data and content to.
You can read The full details at The New Stack.
10: Node.js maturity list
The Node.js maturity checklist will give you a head start on how well Node.js has been adopted by your company.
From building a company culture, training employees, starting to build infrastructure, writing code and running apps, the list will vary depending on your level of acceptance.
You can read the full node.js Maturity Checklist