博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NPM采用Rust以消除性能瓶颈
阅读量:7069 次
发布时间:2019-06-28

本文共 792 字,大约阅读时间需要 2 分钟。

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的最大缺点就是不得不处理另外的栈,包括监控和日志记录。

阅读英文原文:

转载地址:http://duell.baihongyu.com/

你可能感兴趣的文章
架构繁杂,你选择迎难而上还是以退为进?
查看>>
今晚直播丨前端框架三足鼎立,为何还要耗时两年研发一款新的MVVM框架San?
查看>>
阿里双11背后:内部员工们如何高效运作?
查看>>
“云+AI”,华为云使能互联网应用云基础设施创新
查看>>
数据库高可用性简史
查看>>
元宵节离家之前,帮爸妈安装这六个APP才是正经事
查看>>
甘肃敦煌社火“舞”出浓浓年味
查看>>
清者自清!国际泳联为孙杨“药检风波”盖棺定论
查看>>
巴西一大坝垮塌引发泥石流 铁路桥冲断桥身不见踪影
查看>>
韩国瑜:高雄从未这么重要“等了100年才变重心”
查看>>
学习Java的几个阶段,这样走你会学的更好!
查看>>
山西沁县推广生物质能清洁供暖 改造完成4000余户
查看>>
人民币对美元汇率中间价报6.7774元 下调109个基点
查看>>
施耐德电气本土专利“破千”原创战略成果初现
查看>>
热烈祝贺刘鹏教授膺选第45届世界技能大赛云计算赛事中国赛区裁判长!
查看>>
JavaScript是如何工作的:使用MutationObserver跟踪DOM的变化
查看>>
2017年5月iOS招人心得(附面试题)
查看>>
大白话说java并发工具类-Semaphore,Exchanger
查看>>
个推数据统计产品(个数)iOS集成实践
查看>>
在单页应用中,如何优雅的监听url的变化
查看>>