写点什么

Nginx 为什么要造重复的轮子 nginScript

  • 2015-10-14
  • 本文字数:1475 字

    阅读完需:约 5 分钟

前不久,Nginx发布了一种“代理端”的JavaScript 实现 nginScript 。该实现可以提高 Nginx 的脚本能力,使 Nginx 配置更简单、操作更高效,使用户无需编写 C 模块就可以在 Nginx 中做更多的事情。目前, nginScript 解析器仅支持 ECMAScript 5 的一个子集,不过后续还会扩展。在对 JavaScript 求值时,nginScript 会使用一个基于寄存器的虚拟机将 JavaScript 编译成字节码然后在 Nginx(或 Nginx Plus)中运行。

许多人对此都非常好奇,既然已经有了 V8 SpiderMonkey 或其它实现,为什么还要实现一个新的 JavaScript 运行时。 Hacker News 上也出现了大量不同的声音。比如,网友 stanleydrew 就认为这个做法很糟糕,因为它可能让 Nginx 这个原本很棒的工具走上膨胀之路。对此,网友 n42 表示:

任何你不想用的特性都是膨胀,但用到的时候就必要了。

而网友 eknkc 则认为:

它是一个很好的补充。我在高业务量的服务器使用了 Varnish,一个原因就是它有“可视化组件库”,这是一种类 JavaScript 的语言,可以用它来定义请求处理逻辑。nginx 将为熟悉它的人提供许多配置选项。

针对这些疑惑和争论,Nginx 近日专门撰文解释了他们为什么要创建自己的JavaScript 实现。

Nginx 有一些独特的需求,他们希望 nginScript 代码片段可以在 Nginx 处理请求时运行,以此扩展 Nginx 处理请求和响应的能力。但是,他们无意创建一个像 Node.js 那样的持久化的 JavaScript 应用程序运行时环境。

然而,现有的 JavaScript 运行时都是针对 Web 浏览器而设计的,依赖于垃圾收集,很难控制 JavaScript VM 的资源使用。如果内存溢出,它们就会异常退出。这在浏览器端尚可接受,但在服务器端是不可容忍的。他们希望 nginScript 能够提供简洁且可以快速执行的规则,而不是对 JavaScript 的完整支持。而且,Nginx 已经有一个经过充分优化的、事件驱动的架构,所以他们不希望受垃圾收集所带来的性能不可预见性所影响。

出于上述种种考虑,他们实现了一种非常简单但与其需求相匹配的 JavaScript 运行时:

  • 架构——单线程、字节码执行是为了实现快速初始化和处理。由于每个请求会分配一个单独的虚拟机,所以不需要垃圾收集。虚拟机没有复杂的状态或辅助程序初始化,启动速度非常快。
  • 辅助函数——内置操作在 Nginx 本地实现,用户可以将 nginScript 视为一种通过编程驱动 Nginx 本地操作的方式。
  • 预占——Nginx 事件驱动模型负责调度单个 nginScript VM 的执行。当 nginScript 规则执行阻塞操作时,Nginx 会暂停那个虚拟机的执行,待事件完成后再重新调度。这意味着,用户可以采用一种简单线性的方式编写规则,Nginx 会调度它们,而且不会有内部阻塞。

截止目前,nginScript 尚处于早期开发阶段,当前版本为预览版,其团队一直致力于功能的构建,开发主要是围绕完成核心的语言实现以及实现许多内置的 JavaScript 对象(如 Date、Math 等)进行。因此,谈论 nginScript 的性能还为时过早。但测试表明,nginScript VM 的性能同其它解释型语言(PHP、Ruby 等)类似,但不如 JIT 实现快。同时,nginScript 团队还专注于 nginScript VM 与 Nginx 的整合,比如,如何在 Nginx 配置中引用 nginScript 规则,nginScript 如何访问和控制 Nginx 内部构件。对于长时间运行的脚本,他们可能还会引入垃圾收集。nginScript 的完整路线图尚未形成,读者可以通过邮件列表分享自己的想法。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-10-14 19:007016
用户头像

发布了 1008 篇内容, 共 392.7 次阅读, 收获喜欢 344 次。

关注

评论

发布
暂无评论
发现更多内容

Linux系统-磁盘无损扩容教程【宝塔面板适用】

百度搜索:蓝易云

Linux 运维 服务器 云服务器 运维‘

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

BlockChain先知

【安装教程】Linux系统-iftop网络流量监控工具

百度搜索:蓝易云

Linux 云服务器 iftop

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

小哈区块

Centos 8完美升级至Centos 8 Stream教程

百度搜索:蓝易云

Linux centos 云服务器

【超详细】Linux系统修改SSH端口教程

百度搜索:蓝易云

Linux 云服务器 端口 蓝易云 22

linux通过命令查看机器硬件的配置信息【详细】

百度搜索:蓝易云

Linux 运维 cpu 内存 云服务器

【超详细】Linux系统之nethogs命令

百度搜索:蓝易云

Linux 运维 服务器 云服务器 ECS

数据增强之裁剪、翻转与旋转

timerring

人工智能

从钢铁行业数字化管控平台的智能进化,看超自动化能力边界

王吉伟频道

RPA 数字化转型 超自动化 业务流程自动化 钢铁行业

车内语音识别数据:驱动智能出行的新动力

来自四九城儿

车载语音识别

数据交换不失控:华为云EDS,让你的数据你做主

华为云开发者联盟

云计算 华为云 华为云开发者联盟 企业号 7 月 PK 榜

C++中Stack(栈)的使用方法与基本操作

芯动大师

情感语音识别:倾听声音背后的情感

来自四九城儿

情感语音识别

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

大瞿科技

克服困难、提升学习效率的关键方法

叶小鍵

语音识别唤醒词:开启智能化的语音交互时代

来自四九城儿

唤醒词

Linux系统-df命令详解-显示磁盘空间使用情况

百度搜索:蓝易云

Linux 云服务器 df

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

股市老人

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

威廉META

微服务之服务器缓存

Disaster

微服务

代码随想录 Day11 - 栈与队列(中)

jjn0703

深度剖析线上应用节点流量隔离技术

阿里巴巴云原生

阿里云 云原生 流量隔离

走向 Native 化:Spring&Dubbo AOT 技术示例与原理讲解

阿里巴巴云原生

spring 阿里云 云原生 dubbo native

从多元生态、开源到人才培养,让开发者成为决定性力量

华为云开发者联盟

云计算 华为云 华为云开发者联盟 企业号 7 月 PK 榜

华为云河图KooMap:夯实数字孪生底座,点燃燎原星火

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 7 月 PK 榜

一文搞懂常见的加密算法 | 社区征文

闫同学

网络 加密算法 年中技术盘点

一文了解潜力黑马Infiblue:借力Web3,释放元宇宙价值

西柚子

基于云原生网关的全链路灰度实践

阿里巴巴云原生

阿里云 微服务 云原生

链上衍生品协议 ProsperEx:探索 RWA 叙事,打造 DeFi 变异黑马

股市老人

Nginx为什么要造重复的轮子nginScript_JavaScript_谢丽_InfoQ精选文章