Vert.x 与 Node.js 有哪些区别

发布网友 发布时间:2022-04-23 13:06

我来回答

3个回答

热心网友 时间:2022-05-23 14:03

Vert.x是一个用于下一代异步、可伸缩、并发应用的框架,旨在为JVM提供一个Node.js的替代方案。开发者可以通过它使用JavaScript、Ruby、Groovy、Java、甚至是混合语言来编写应用。

在内部,一个vert.x实例会管理着一个小的线程集合,每个线程针对服务器上的一个可用内核。基本上每个线程都实现了一个事件循环。当部署一个vert.x应用实例(又叫做verticle)时,服务器会选择一个事件循环分配给该实例。接下来针对该实例的任务都会通过该线程进行分配。由于在某一时刻可能会有成千上万个verticle在运行,因此在同一时刻会将单个事件循环指定给多个verticle。

Verticle可与运行在相同或不同vert.x实例中的其他verticle进行通信,这是通过消息事件总线实现的,它类似于Erlang的actor模型。消息传递旨在让系统能够在多个可用核心上进行扩展而无需以多线程的方式来执行verticle代码。

事件总线是分布式的,并不只会跨越服务器,还会渗透进客户端的JavaScript以处理“实时”的Web应用。

除了并发与消息传递外,vert.x还具有如下特性:

TCP/SSL服务器与客户端
HTTP/HTTPS服务器与客户端
WebSockets/SockJS支持
InfoQ有幸采访到了VMWare的高级工程师Tim Fox以了解vert.x:

InfoQ:能否从架构上介绍一下vert.x及其构建方式?

Tim:vert.x的核心是用Java编写的,接下来我们为每一种支持的JVM语言编写了一个薄薄的API层,这样每种语言都有一个适合于该语言的API了。我们并没有向这些语言直接公开Java API。这意味着Ruby用户会通过Ruby的方式编写代码,JS用户会通过JS的方式编写代码。

InfoQ:能否描述一下在vert.x上典型的开发流程么,特别是与开发者使用Node.js的体验进行一下对比?

我觉得这与node.js是非常类似的。实际的工作流程取决于你是在本地还是云中运行应用。但这并非vert.x所特有的。

InfoQ:就调试、监控与运维来看,在JVM与Node.js上运行实时应用有何差别?

我想说监控与运维实际上与部署vert.x的环境之间的关系更为密切而非vert.x本身。比如说,如果将vert.x部署到云中,那么云提供商可能就会为你提供监控。顺便说一下,社区成员目前已经在OpenShift与Heroku上运行了Vert.x。我们希望不久之后CloudFoundry支持就会到来。

InfoQ:vert.x与Node.js有什么基准比较么?

我们尚未发布任何的官方基准。但我自己已经完成了一些,在我所做的测试中,vert.x的性能与可伸缩性都远远超越了node.js。我希望在不久之后能够发布一些基准。

InfoQ:vert.x与Netty相比如何呢?

Netty是个很棒的底层IO库。Vert.x实际上使用了Netty。但vert.x是个用于编写异步应用的完整平台。Vert.x还提供了一个组件模型、文件IO及各种Netty所没有的东西。我要说的是,在JVM世界中,Vert.x是更类似于Akka(也使用了Netty)之类的完整框架。

热心网友 时间:2022-05-23 14:03

刚刚看了一下vert.x,觉得其思路还是很不错的。主要是提供了多语言包装进入一个异步eventbus来提供新式的actor模型体系的装置。这一动作的意义是重大的,可以让众多传统思维体系的程序员和开发进入异步的世界。

  但是异步的模型对于一般人的挑战还是较大,写vert.x时还是用js和q这样的promise库比较方便。而总线上传输的还是json。

  所以,如果你个人或者公司在java上面的已有投资已经非常大,那么采用vert.x可以让你进入异步的世界,用上netty的高性能,并且拥有较好的总线传递机制和actor模型,不过你还是要面对call ba c k的问题。

  如果你不是上面的情况,那么就投入no d j e s的怀抱吧。node生态和运用现在已经相当成熟了。而如果不喜欢callback,新的generator模型也已出来。

热心网友 时间:2022-05-23 14:04

刚刚看了一下vert.x,觉得其思路还是很不错的。主要是提供了多语言包装进入一个异步eventbus来提供新式的actor模型体系的装置。这一动作的意义是重大的,可以让众多传统思维体系的程序员和开发进入异步的世界。
但是博主也说了,异步的模型对于一般人的挑战还是较大,写
vert.x时还是用js和q这样的promise库比较方便。而总线上传输的还是json。
所以,如果你个人或者公司在java上面的已有投资已经非常大,那么采用vert.x可以让你进入异步的世界,用上netty的高性能,并且拥有较好的总线传递机制和actor模型,不过你还是要面对call ba c k的问题。
如果你不是上面的情况,那么就投入no d j e s的怀抱吧。node生态和运用现在已经相当成熟了。而如果不喜欢callback,新的generator模型也已出来。
相信我,json以及js带给你的,不是枷锁,而是整个世界:)

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com