对于Node.js开发者来说,2016是振奋人心的一年。 看看这张图就知道我的意思了:
回首Node.js从无到有的6年,我们可以大声宣布我们最爱的框架已经长大成人——基本上世界上每个行业的牛逼公司都开始使用它。
另外一个好消息是Node.js已经成为史上最大的开源平台——每月1500万和每周超过10亿的下载量足以证明。我们有超过1100位开发者来为Node.js的开源平台添钻加瓦,正因如此,其贡献量也达到了历史峰值。
? Code and Learn #Node开发者交流大会#将会把@nodejs 的核心贡献者推到高达1100的高度 — Tierney Cyren (@bitandbang) 2016年12月1日 译者注释:Code and Learn是一个Nodejs的组织,他们举办的会议叫NodeInteractive,翻译成我们日常用语就是Node开发者交流大会
回顾这一年,我们精心挑选了十大文章,大家走过路过不要错过。这些内容围绕2016这一年中Node.js的发展,包罗万象好坏兼顾。
让我们一起来看看吧!
程序员们都震惊了!!!眼睁睁的看着编译失效、安装失败,而这一切都是Azer Koçulu在16年3月将他自己的250个模块从NPM中下线导致的———搞垮了不计其数的模块,包括Node和Babel
译者注释:果然不要得罪程序员……
Koçulu删除自己代码的原因是他有一个叫Kik的模块——和那个即时通信应用同名,正因如此,Kik的律师声称其侵权,之后NPM就直接移除了他的模块。
“这件事让我意识到NPM只是某些人的私有领域,公司在那里比普通人更有权利,而我开源只因权利属于人民” - Azer Koçulu 译者注释:Power To The People是美国常见的标语,这里直译为“权利属于人民”,可以参考wiki https://en.wikipedia.org/wiki/Power_to_thepeople(slogan)
Azer有一个叫做left-pad的模块,其可以用0和空格将字符串左边进行填充。不幸的是,一大堆模块对其有依赖。
整件事的后续可以在The Register's great article 查看到,事件的更新也会及时布告在上面。
2016年十月,Facebooke联合Google发布了Yarn,一个全新的JavaScript包管理工具
为啥要搞这个?Facebook的工作流在融合npm时出现了不少原则性的问题
与其说用hack的方式绕过npm的限制,Facebook索性自己从头开始,开发了Yarn:
译者注释:其实就是造轮子
Yarn向不在Facebook工作的开发者宣称其可以带来大幅度的性能提成,但是,其使用的还是npm的注册机制,本质上只是npm客户端的仿制品
你可以在TechCrunch上了解到全文的细节内容。
对Node.js新增的调试能力支持已在五月份合并到Node.js主干
使用新的调试工具,你需要
nvm install node
inspect
参数运行Node: node --inspect index.js
可以通过阅读此文章Read the great tutorial from Paul Irish了解所有特性和相关细节!
Jonathan Zarra,GoChat for Pokémon GO的创建者,在五天内获得了一百万用户。Zarra在支付服务器成本上颇感压力(大约 4,000美元 / 月),然而维护一百万的活跃用户相关费用是必不可少的。
他做梦的没想到会有如此多的用户。 他是用 MVP(Minimum Viable Product,最小化可行产品) 的方法来构建这个 app 的,还没有考虑可扩展性。他只是用这个来试错。
Zara之前已经和VC们讨论过这个应用的发展和盈利。由于他构建这个 app 只是作为 MVP,他以为可以等以后再来考虑可扩展性。
他错了。
由于其简陋的设计, GoChat没有办法扩展到足以支撑这么多用户,于是系统就 down 了。 钱花了,用户却都走了
Unboxd的CTO Erik Duindam究其一生在设计构建网络平台的工作上,服务了不计其数的活跃用户。
受挫于Zarra的GoChat的简陋设计和霉运,Erik决定自己搞出一套方案, GoSnaps: 为Pokémon GO而生的Instagram/Snapchat。
Erik使用Node.js在24小时里开发一个可以轻松处理50万独立用户的 MVP 应用。
所有的安装只是搭建在一个100美元/月的中型Goolge云服务器上,外加一个用来存储图片的(简易版)Google云存储服务——而其性能却格外显著。
他是怎么做到的? 想知技术细节如何,请阅读下文:
读下我的 《100块的服务器+5天=50万用户,我是怎么做到的,你猜?》 https://t.co/euP0OFJdZJ #startups #pokemongo #tech — Erik Duindam (@erikduindam) July 18, 2016
Node明星教程系列的目的是帮助开发新人从0开始学习Node.js,进而用其交付软件产品!
你可以从下面找到所有内容:
此教程可以帮助你使用RabbitMQ来协调生产者和消耗者之间的工作。
不像Redis, RabbitMQ唯一目的是提供一个可靠和可扩展的通信解决方案,以及目前在Redis上没有或者很难实现的特性。
RabbitMQ是一个跑在本地或者网上某些node端的服务器。客户端可以是工作进程和消耗者的其一或兼顾,其使用高级通信列队协议(AMQP)来和服务器对话。
你可以在这里阅读完整的教程
IBM的Node.js技术老大James M Snell在九月底参加了他的第一次TC-39会议。
为啥?
一个被TC-39定义的JavaScript语言特性,或者说是模块,已经给Node.js核心团队引起了不少麻烦了。
James和Bradley Farias (@bradleymeck)一直在试图寻找怎么在Node.js中用最好的方式实现对ECMAScript模块(ESM)的支持,而不会引起更多不必要的麻烦和困惑
图片上文字翻译如下: 事实证明,Node.js和TC-39对于模块的相关问题有很大的分歧:什么是,如何定义,以及他们怎样被载入内存和使用。 从最开始,Node.js已经有一套起源于CommonJS,相当宽松的模块系统。
由于涉及的问题十分复杂,与TC-39促膝长谈看起来才是目前最高效的促进方法。
全文讨论了他们从对话中所发现和理解的内容。
2016年夏天我们在Trace by RisingStack进行了一项问卷调查,以了解开发者们是如何使用Node.js的。
结果显示:对于Node.js应用的开发,打包和发布来说,MongoDB, RabbitMQ, AWS, Jenkins, Docker和Amazon Container Services是首选。
结果同样表明Node开发者主要的痛点是:调试
你可以在《这里有Node.js调查结果和图表展示》阅读完整内容。
Node基金会在北美Node.js开发者大会上宣布其将接手Node.js安全项目,此项目是由Adam Baldwin所创建,之前由^Lift所管理。
作为Node.js基金会的一部分,Node.js安全项目将提供一个统一的流程,以探索和挖掘在Node.js模块生态系统中发现的安全漏洞。基金会里的一个小组会负责项目的管理工作。
Node.js基金会将从^Lift那接管下列事宜:
你可以在The New Stack了解到全文细节。
Node.js成熟度清单可以让你开始着手了解Node.js在你公司的接纳程度。
从建立公司文化,培训员工,着手构建基础设施,编写代码和运行应用等方面出发,清单因你接受度的不同而异。
快扫描二维码,与志佳老师来聊聊吧~~