NPM采用Rust以消除性能瓶颈

作者:Sergio De Simone

2019 年 3 月 19 日

NPM采用Rust以消除性能瓶颈

Npam 的指数级增长促使 npm 工程团队从 Node.js 切换到 Rust,以处理那些将成为性能瓶颈的 CPU 绑定任务。最近的一份白皮书概述了在 Rust 中开发这个新服务,以及将其投入生产一年多的经验。

大部分 npm 操作是流量密集型的,Node.js 正是针对这种场景设计的。但是,npm 工程师们发现,确保只有授权用户可以发布包的授权服务显示出令人担心的计算密集型负载。Npm 工程师 Chris Dickinson 解释到,因为身份验证服务有点过时了,所以做出从头开始重写它的决定并不难。因此,npm 工程师开始寻找最适合该任务的编程语言。因为缺乏内存安全性,C 和 C++ 很快就被排除在外,而 Java 因为依赖虚拟机,也出局了。剩下的语言有两种,分别是 Go 和 Rust。为了更好地评估最终解决方案,npm 团队决定用这两种语言以及 Node.js 分别重写他们的身份验证服务,以便进行比较。

不可否认,npm 的身份验证服务没那么复杂,以 Node.js 重写只花了一个小时。另一方面,Go 需要 2 天,但以 Rust 重写花了整整一个星期,主要是因为 Rust 的学习曲线更加陡峭以及该语言的内在复杂性,Chris Dickinson 这样解释说。

我们将编写一个正确的程序,但是,我们必须思考该正确程序的方方面面。

最后,npm 团队决定部署 Rust 版本的身份验证服务,这主要归功于他们获得来自 Rust 社区的强力支持,以及与当时 Go 能提供的包管理器相比,Rust 包管理器 Cargo 具有优势。

对 npm 团队来说,好消息是 Rust 服务已经在生产环境中运行一年有余,没有任何告警。这与在 npm 部署 Node.js 服务的常规经验形成鲜明对比,为让错误和资源的使用可控,在 npm 部署 Node.js 要包括大量的监控。消极的一面是,根据 Chris Dickinson 的说法,在 npm 引入 Rust 的最大缺点就是不得不处理另外的栈,包括监控和日志记录。

阅读英文原文: NPM Adopted Rust to Remove Performance Bottlenecks

2019 年 3 月 19 日 00:00 10174
用户头像

发布了 199 篇内容, 共 63.4 次阅读, 收获喜欢 268 次。

关注

评论 2 条评论

发布
用户头像
nodejs稳定性成疑,开发效率不错,WYSWYG,client端的确非常合适。
rust开发效率这么看来非常堪忧啊,稳定性的确赞——可以取代ADA么?毕竟波音PHP都能用。
java暂时中庸,在服务器端是霸主地位啊。
2019 年 03 月 21 日 10:44
回复
用户头像
似乎没有比较 go 和 rust 的性能,毕竟rust的开发耗时远高于go
2019 年 03 月 19 日 23:10
回复
没有更多评论了
发现更多内容

第三周作业

胡江涛

极客大学架构师训练营

搞定 HTTP 协议(三):如何严谨地描述一个 HTTP 报文?

零和幺

https HTTP

week3 学习总结

耕夫

ARTS-WEEK4

一周思进

ARTS 打卡计划

Open-Falcon安装注意事项

wong

Open-Falcon Nightingale Monitor

代码重构-学习总结

飞雪

Spring 源码学习 - @Async注解实现原理

公众号:好奇心森林

Spring Boot aop

区块链中的“链上”和“链下”

CECBC区块链专委会

区块链技术 分布式身份标识 难以篡改

第三周总结

胡江涛

极客大学架构师训练营

架构师训练营-第 03 周作业提交

rainbowbox

极客大学架构师训练营

十万同时在线用户,需要多少内存?——Newbe.Claptrap 框架水平扩展实验

newbe36524

架构师训练营 - 第 02 周学习总结

rainbowbox

程序员的晚餐 | 6 月 21 日 自制小火锅

清远

美食

Go:使用Delve和Core Dump来调试

陈思敏捷

go golang debug gdb

Feign Client 原理和使用

公众号:好奇心森林

Spring Boot HTTP

架构师训练营第 3 周 _ 课后作业

方舟勇士

课程作业

138 张图带你 MySQL 入门

cxuan

MySQL 数据库

设计模式练习及感想(训练营第三课)

看山是山

设计模式 极客大学架构师训练营

技术学习进阶(死磕法)

dudu

学习方法 技术

设计模式学习总结

qihuajun

week3 命题作业

耕夫

ARTS 第 3 周

乌拉里

信息的表示与存储-整数的运算

引花眠

计算机基础

架构师训练营 - 第三周总结

teslə

ARTS打卡 第4周

引花眠

ARTS 打卡计划

架构师训练营-第 02 周作业

rainbowbox

三周作业

飞雪

单例模式和组合模式

王鹏飞

易纲:上海可以在人民币自由兑换等方面先行先试

CECBC区块链专委会

数字货币 区块链技术 金融科技中心

架构师训练营-第 03 周总结

rainbowbox

极客大学架构师训练营

架构师训练营 - 第三周作业

teslə

NPM采用Rust以消除性能瓶颈-InfoQ