Express作者TJ告别Node.js奔向Go


Posted in Javascript onJuly 14, 2014

首先这是一篇翻译自TJ 的 Farewell Node.js  ,我本人在看完这这篇文章之后确实是受到了一些冲击,但我并不认同作者的某些看法,比如我认为 Node.js 的package register 是其许多优势之一,反而 Go 在这方面却略显匮乏。 由于个人水平所限,在翻译的时候有许多不懂的地方,我也去作者博客、stackoverflow 上问了一些问题,获得了解答。翻译仍有许多不到位的地方,希望能获得指出意见。

PS.  作为一位Node.js 的入门菜鸟,感谢TJ 的付出,一路走好。

正文:

告别Node.js

离开Node.js领域

我一直与Node.js在生产中一起战斗了足够久的时间,很不幸的是,既然我已经不再喜欢从事这份工作,至少在此刻,这是我的正式告别。更重要的是,我需要维护者。

        Node在一些方面确实很棒,但对于最近我感兴趣的软件类型,它终究不是适合的工具。我仍然计划用Node做网站,但如果你对维护任何项目感兴趣,只需要留言写下你的Github 用户名 ,  npm 用户名,以及项目名称来让我知道。通常我所要求的只有你不彻底的改变已有的api,如果真要这么做的话,还是重新开一个新项目的好。

         Koa  是一个我会继续去维护的项目。(与Co 还有朋友们一块)

圣杯的故事

我一直深爱着C,但每一个从事C开发工作的人都知道它是有价值却又易于出错的。很难在日常工作中证明语言的选择,因为它不完全是最快的工作。简洁也是一直赞美它的原因,但是没有大量的模板你不会走得很远。

随着越多的参与分布式系统的开发,Node性能高过可用性与健壮性的发展趋势让我越发沮丧。在过去的一个星期中,我已经用Go重写了一个相对大型的分布式系统,它的健壮性、性能更好,并且易于维护,由于同步代码普遍的更加优美并且更易于开发,它有着更好的可测试覆盖范围。

        我并不是说Go就是一个圣杯,它并不完美,但对于现今存在的多种语言来说,Go于我是一个极好的答案。随着越来越多的这些"次世代"语言如 Rust 和 Julia 找到他们自己的位置并成熟起来,我确定我们会有更多的伟大的解决方案。

        个人而言我对Go语言感到很兴奋是因为他的迭代速度,很激动的看到他们渴望去达到2.0版本,并且据我所听到的消息,他们并不害怕与打破原有的伟大事物。如果是真的话我很乐意,更多是因为我相信如果真的是有益于这门语言的,就应该快速的打破已有事物。但我也不是一个运行了大量系统的软件巨人。:D

        编著: 一定是我错误解读了一些提交的邮件列表,他们在任何时候都并不渴望于做出一些破坏性的改变。@enneff

为什么是Go?

如果Node对你有效并且你没有什么需要担心的,它仍然是一个很好的工具。但如果有些事情困扰着你,别忘了跳出你的盒子去看看在盒子外面有什么其他的--在最初的使用Go来构建产品的几个小时内,我已经被吸引住了。

再次声明,我并不是在那里说Go绝对是最好的语言而且你必须去使用它。但对于它所处年纪来说,是非常成熟而健壮的。(大致与Node相同年纪的时候)。类型的重构是有趣而简单的,Go所提供的作业和调试工具是很棒的,同时社区具有非常强大的关于文档、格式、基准以及api设计方面的条例。

        在如此习惯于极度模块化的Node 和体验过 Ruby 腐烂的标准库的同时,当我第一次听到 Go,我认为它的标准库是糟糕的。在我深入这门语言之后,我意识到现阶段极大部分的标准库都是很有必要的,比如compression、json、IO、buffered IO、字符串操作等等。大部分的这些APIS 都被定义的很好并且很强大。很容易仅仅通过使用这些标准库来书写整个程序。

第三方Go packages

大部分的Go 库看上去都很相似,我到目前为止所使用过的大部分的第三方代码都是高质量的,而在Node中很难去找到这些因为JavaScript 吸引了不同技巧层次范围内的开发者。

        对于Go 的packages 来说,没有注册中心,所以你通常会同时看到5或6种相同的包。在有些时候,这会造成一定的困惑,但它却有一个有趣的副作用,你必须通过认真的审查每个包来决定哪一个是最佳方案。通过Node 通常有规范的包如 "redis","mongodb-native" 或者"zeromq",所以你会停在那里就推断出他们是最好的一个。

        如果你正在做一些分布式的工作,你会发现Go的令人印象深刻的并发基础数据类型是非常有帮助的。我们可以通过在Node 中的generators 来获得相似的东西,但在我看来,generators 仅仅是做到一半而已。没有独立的错误处理、报告栈即使最好也仍然是平凡的。当这些方案都能良好运行的时,我也不想等待社区三年去重整。

 在我看来,Go的错误处理是出众的。就你必须考虑每一个错误并且决定怎么做而言,Node是伟大的。然而Node 失败在:

你或许会重复的进行回调

你或许根本不会进行回调 迷失在不稳定状态中 (译注 比如忘记传递错误处理回调,错误时,Node 将吞掉这个错误而不会有任何反馈)

你或许会得到外带的错误

emitters 或许会获得多个错误的事件

忘记错误的事件的处理会毁掉一切

经常不确定什么需要错误的处理

错误的处理是非常冗余的

回调烂透了
在Go语言中,当我的代码结束的时候,它就结束了,你不能在语句中重新执行。在Node中这是不确定的。你会认为一个程序完全的执行完毕,直到一个库意外的多次调用一个回调,或者没有正确的清除handlers 然后引起代码的再次执行。实际的生产代码中找到这些原因是相当困难的,为什么要烦恼这些?其他语言不会让你经历这些痛苦。

未来的Node

我仍然希望Node 做得很好,许多的人对他进行巨额的投资,它确实有这样的潜质。我认为Joyent 和团队需要关注在可用性—如果你的应用很脆弱并且很困难去调试、重构以及开发,性能是无意义的。

        在4-5年内我们仍然将有着这种模糊不清的错误 "Error: getaddrinfo EADDRINFO”,这个事实告诉我们Node 的发展优先级在哪里。可理解的是,当你专注于建立系统核心的时候,会很容易漏掉这些东西。单我认为用户已经对这类事物一次又一次的表达了意见却没看到任何的结果。对于声称说我们拥有的已经是完美的,我们通常获得少数的回应。在实践中,却并非如此。

       streams 是被中断的, 回调不容易使用,错误含糊不清,工具并不好用,社区条例是有,相对于Go而言却显得匮乏。尽管如此,一些特定的任务我仍可能继续去使用Node,比如创建网页,或者一些零散的API或者原型。如果Node可以修复一些它的基本问题,那么它有机会保持相关性,但当存在另一方案是更高的性能和更高的可用性的时候性能高于可用性的论证不会走的太远。

 如果Node社区决定去拥抱generators 并能在Node 非常核心的地方实现他们,去适当的传递错误,是有机会让这个是可参照的。这会彻底的提高Node 的可用性以及健壮性。

 好消息是,不久之前我跟在 StrongLoop  里面的贡献核心代码的了不起并充满天赋的家伙聊过。他们正在明确的采用通过倾听开发者对这个平台的回复,并且计划找到修复这些问题去修复的正确方式让未来的Node更加易于工作。我不确定多家公司对核心部分同时开发的冲突会如何结束,但我希望开发者驱动方会胜出。

        这并不意味着这是一个对个人的攻击,很多真的有天赋的人们正在与Node或在Node之上工作,但这再也不是我感兴趣的地方了。我在Node社区中经历了一段伟大时光的同时也遇到了一些真的很有趣的人。

        故事的寓意在于,不要被你自己的圈子所限制住!看看其他地方有什么,你也许会再次享受编程。在这之外还有很多了不起的解决方案,我犯的错在于等了太久才去与他们一起游戏!

Javascript 相关文章推荐
jQuery数组处理方法汇总
Jun 20 Javascript
JavaScript高级程序设计 DOM学习笔记
Sep 10 Javascript
妙用Jquery的val()方法
Jun 27 Javascript
js生成随机数之random函数随机示例
Dec 20 Javascript
js获取当前日期前七天的方法
Feb 28 Javascript
深入探究使JavaScript动画流畅的一些方法
Jun 30 Javascript
javascript事件的传播基础实例讲解(35)
Feb 14 Javascript
详解本地Node.js服务器作为api服务器的解决办法
Feb 28 Javascript
Vue实现左右菜单联动实现代码
Aug 12 Javascript
JS面试题大坑之隐式类型转换实例代码
Oct 14 Javascript
Vue 组件修改根实例的数据的方法
Apr 02 Javascript
react-intl实现React国际化多语言的方法
Sep 27 Javascript
node.js不得不说的12点内容
Jul 14 #Javascript
Node.js编码规范
Jul 14 #Javascript
给js文件传参数(详解)
Jul 13 #Javascript
js中自定义方法实现停留几秒sleep
Jul 11 #Javascript
使用jquery prev()方法找到同级的前一个元素
Jul 11 #Javascript
让checkbox不选中即将选中的checkbox不选中
Jul 11 #Javascript
常用jQuery选择器总结
Jul 11 #Javascript
You might like
解析php时间戳与日期的转换
2013/06/06 PHP
discuz加密解密函数使用方法和中文注释
2014/01/21 PHP
Win2003+apache+PHP+SqlServer2008 配置生产环境
2014/07/29 PHP
php组合排序简单实现方法
2016/10/15 PHP
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
jQuery中判断一个元素是否为另一个元素的子元素(或者其本身)
2012/03/21 Javascript
漂亮的jquery提示效果(仿腾讯弹出层)
2013/02/05 Javascript
js 动态为textbox添加下拉框数据源的方法
2014/04/24 Javascript
JQuery中$.each 和$(selector).each()的区别详解
2015/03/13 Javascript
详解js中构造流程图的核心技术JsPlumb
2015/12/08 Javascript
AngularJS控制器之间的数据共享及通信详解
2016/08/01 Javascript
JavaScript 实现的checkbox经典实例分享
2016/10/16 Javascript
微信小程序 wxapp内容组件 text详细介绍
2016/10/31 Javascript
js实现HashTable(哈希表)的实例分析
2016/11/21 Javascript
koa2使用ejs和nunjucks作为模板引擎的使用
2018/11/27 Javascript
OPENCV去除小连通区域,去除孔洞的实例讲解
2018/06/21 Python
浅谈python3.x pool.map()方法的实质
2019/01/16 Python
Python confluent kafka客户端配置kerberos认证流程详解
2020/10/12 Python
如何用python 操作zookeeper
2020/12/28 Python
css3实现文字首尾衔接跑马灯的示例代码
2020/10/16 HTML / CSS
举例详解HTML5中使用JSON格式提交表单
2015/06/16 HTML / CSS
HTML5 SEO优化的一些建议
2020/08/27 HTML / CSS
经典c++面试题三
2015/07/08 面试题
市场营销个人求职信范文
2014/02/02 职场文书
工商企业管理专业自荐信范文
2014/04/12 职场文书
项目申请汇报材料
2014/08/16 职场文书
干部个人对照检查材料
2014/08/25 职场文书
三方股东合作协议书
2014/10/28 职场文书
敬老院活动感想
2015/08/07 职场文书
多人股份制合作协议书
2016/03/19 职场文书
2019年让高校“心动”的自荐信
2019/03/25 职场文书
辞职信怎么写?你都知道吗?
2019/06/24 职场文书
新店开业策划方案怎么书写?
2019/07/05 职场文书
Python趣味挑战之实现简易版音乐播放器
2021/05/28 Python
基于Pygame实现简单的贪吃蛇游戏
2021/12/06 Python
MySQL详细讲解变量variables的用法
2022/06/21 MySQL