目前最快的 Java 框架居然是它?真的最快,秒射~

如果您搜索“最佳网络框架”,您可能会偶然发现Techempower基准测试,其中排名超过300个框架,在那里你可能已经注意到Vert.x是排名最高的。

Vert.x是一个多语言 Web 框架,它支持Java,Kotlin,Scala,Ruby和Javascript支持的语言之间的共同功能。无论语言如何,Vert.x都在Java虚拟机(JVM)上运行。模块化和轻量级,它面向微服务开发。

Techempower基准测试衡量从数据库更新,获取和交付数据的性能。每秒提供的请求越多越好。在这种涉及很少计算的IO场景中,任何非阻塞框架都会有优势。近年来,这种范式几乎与Node.js不可分割,Node.js通过其单线程事件循环来推广它。

与Node类似,Vert.x运行单个事件循环。但Vert.x也利用了JVM。Node运行在单个核心上,而Vert.x维护的线程池大小可以与可用核心数相匹配。凭借更强的并发支持,Vert.x不仅适用于IO,也适用于需要并行计算的CPU繁重流程。

然而,事件循环只是故事的一半。另一半与Vert.x几乎没有关系。Java必备的 15 个框架,推荐看下。

要连接到数据库,客户端需要连接器驱动程序。在Java领域,Sql最常见的驱动程序是JDBC。问题是,这个驱动程序阻塞了。它在套接字级别阻塞。一个线程总会卡在那里,直到它返回一个响应。

毋庸置疑,驱动程序一直是实现完全无阻塞应用程序的瓶颈。幸运的是,在具有多个活动分叉的异步驱动程序上取得了进展(尽管是非官方的),其中包括:

黄金法则

使用Vert.x非常简单,只需几行代码即可启动http服务器。

val vertx = Vertx.vertx()
vertx.createHttpServer().requestHandler(req => {
    
}).listen(8080)

方法requestHandler是事件循环传递请求事件的地方。由于Vert.x没有意见,处理它是自由的风格。但请记住非阻塞线程的唯一重要规则:不要阻止它。

在使用并发时,我们可以从如今的许多选项中获取,例如Promise,Future,Rx,以及Vert.x自己的惯用方法。但随着应用程序复杂性的增加,单独使用异步功能是不够的。我们还需要轻松协调和链接调用,同时避免回调地狱,以及优雅地传递任何错误。

Scala Future满足上述所有条件,并具有基于函数式编程原理的额外优势。虽然本文不深入探讨Scala Future,但我们可以通过一个简单的应用程序来尝试它。

假设该应用程序是一个API服务,用于查找给定其ID的用户:

val vertx = Vertx.vertx()
vertx.createHttpServer().requestHandler(req => {

req.path() match {
  case p if p contains("/user") =>
  val f = for {
    f1 <- Future { req.getParam("id").get.toInt }
    f2 <- if (f1 < 100) Future.unit else Future.failed(CustomException())
    f3 <- Future { getUserFromDb(f1) }
  } yield f3
  f map (r => printout(req, r)) recover {case exception => printout(req, handleException(exception))}

  case _ => printout(req, "Default page")
}

})
.listen(8080)

def printout(req: HttpServerRequest, msg: String) = req.response().end(msg)

def handleException(e: Throwable): String = {
e match {
  case t: NoSuchElementException => "Missing parameter"
  case t: NumberFormatException => "Parameter not number"
  case t: CustomException => "Custom exception"
  case t: SQLException => "Database error" 
  case _ => "Unknown error"
}
}

def getUserFromDb(id: Int) = "mock user name"

case class CustomException() extends Exception("custom exception")

涉及三个操作:检查请求参数,检查id是否有效以及获取数据。我们将把这些操作包装在Future中,并在“for comprehension”结构中协调执行。

第一步是将请求与服务匹配。

Scala具有强大的模式匹配功能,我们可以将其用于此目的。在这里,我们拦截任何提及“/ user”并将其传递给我们的服务。

接下来是这项服务的核心,我们的期货按顺序排列。

第一个furture 未来f1包装参数检查。我们特别想从get请求中检索id并将其转换为int。(如果返回值是方法中的最后一行,Scala不需要显式返回。)如您所见,此操作可能会抛出异常,因为id可能不是int或甚至不可用,但现在可以。

第二个furture f2检查id的有效性。

我们通过使用我们自己的CustomException显式调用Future.failed来阻止任何低于100的id。否则,我们以Future.unit的形式传递一个空的Future作为成功验证。

最后的furture f3将使用f1提供的id检索用户。

由于这只是一个示例,我们并没有真正连接到数据库。我们只返回一些模拟字符串。

map运行从f3生成用户数据的排列,然后将其打印到响应中。

现在,如果在序列的任何部分发生错误,则传递Throwable进行恢复。

在这里,我们可以将其类型与合适的恢复策略相匹配。回顾一下我们的代码,我们已经预料到了几个潜在的失败,例如缺少id,或者id不是int或者无效会导致特定异常。我们通过向客户端传递错误消息来处理handleException中的每一个。

这种安排不仅提供从开始到结束的异步流程,还提供处理错误的干净方法。由于它是跨处理程序的简化,我们可以专注于重要的事情,如数据库查询。

Verticles,Event Bus和其他陷阱

Vert.x还提供了一个名为verticle的并发模型,类似于Actor系统。Verticle隔离其状态和行为以提供线程安全的环境。与之通信的唯一方法是通过事件总线。

但是,Vert.x事件总线要求其消息为String或JSON。

这使得传递任意非POJO对象变得困难。在高性能系统中,处理JSON转换是不可取的,因为它会带来一些计算成本。如果您正在开发IO应用程序,最好不要使用Verticle或事件总线,因为这样的应用程序几乎不需要本地状态。

使用某些Vert.x组件也非常具有挑战性。

您可能会发现缺少文档,意外行为甚至无法正常运行。Vert.x可能正在遭受其雄心壮志,因为开发新组件需要移植多种语言。这是一项艰巨的任务。因此,坚持核心将是最好的。

如果您正在开发公共API,那么vertx-core就足够了。如果它是一个Web应用程序,您可以添加vertx-web,它提供http参数处理和JWT / Session身份验证。

无论如何,这两个是主导基准的。在使用vertx-web的一些测试中,性能有所下降,但由于它似乎源于优化,因此可能会在后续版本中得到解决。

来源:https://www.jdon.com/51872

大家有用 Vert.x 的吗?欢迎留言分享~

### 回答1: 选择最好的开源框架取决于您的项目需求和目标。但是,在 Java 开发领域,以下框架被广泛认为是非常优秀的: 1. Spring Framework:这是 Java 社区最受欢迎的框架之一,用于构建企业级应用程序。 2. Struts:这是一个用于构建基于 Web 的 Java 应用程序的框架。 3. Hibernate:这是一个非常流行的 Java 持久层框架,用于与数据库进行交互。 4. Apache Spark:这是一个大数据处理框架,可以帮助您快速处理大量数据。 5. Apache Tomcat:这是一个开源的 Web 应用服务器,可以为您的 Web 应用程序提供服务。 这些框架都是非常强大的,具体选择哪个取决于您的项目需求和目标。 ### 回答2: 很难说JAVA有一个绝对最好的开源框架,因为每个开源框架都有自己的优点和适用场景。以下是一些常见和受欢迎的JAVA开源框架: 1. Spring框架:Spring是一个轻量级的开源框架,提供了全面的解决方案,包括依赖注入、面向切面编程、事务管理等。它具有模块化设计,易于扩展和整合其他框架。 2. Hibernate框架:Hibernate是一个对象关系映(ORM)框架,用于将Java对象映到关系数据库。它简化了数据库操作,提供了强大的查询和持久化功能。 3. Apache Struts框架:Struts是一个MVC框架,用于构建基于Java的Web应用程序。它提供了请求处理、表单验证、视图渲染等功能,使开发者能够快速开发可扩展和易维护的Web应用。 4. Apache Maven框架:Maven是一个项目管理和构建自动化工具。它提供了一种简单的方式来管理项目依赖、构建过程和项目文档。它还支持插件机制,使开发者能够扩展和定制构建过程。 5. Apache Kafka框架:Kafka是一个分布式流处理平台,用于处理实时数据流。它具有高吞吐量、可伸缩性和容错性,可以在分布式环境中处理大量的消息。 这些框架都是开源的,具有活跃的社区支持和广泛的使用。选择最适合的开源框架取决于项目需求、团队技能和个人偏好。 ### 回答3: Java拥有众多优秀的开源框架,很难说哪一个是最好的,因为每个框架都有自己的特点和适用场景。但以下几个开源框架Java开发中非常流行和被广泛应用: 1. Spring框架:Spring是Java开发中最常用的开源框架之一。它提供了一个轻量级的容器,用于管理Java对象的生命周期和依赖关系。Spring还提供了各种功能模块,如数据访问、事务管理、安全性、Web开发等。Spring的优点包括灵活性、可扩展性和易于集成其他框架。 2. Hibernate框架:Hibernate是Java中最流行的ORM(对象关系映框架之一。它将Java对象和数据库表之间建立映关系,实现了面向对象的数据访问。使用Hibernate,开发人员可以通过简单的配置实现数据库操作,无需编写复杂的SQL语句。Hibernate具有高度的可移植性和灵活性,在大多数Java项目中都得到了广泛应用。 3. mybatis框架:mybatis是另一个流行的Java持久化框架,它通过XML或注解的方式,将Java对象映到关系数据库中。相比于Hibernate,mybatis更加轻量级,提供了更直接的SQL控制和优化能力。它具有较高的性能和灵活性,适用于需要精细控制SQL和数据库操作的项目。 总结而言,以上三个框架都是Java开发中非常值得推荐的开源框架。根据不同的需求和项目特点,选择适合自己的框架可以提高开发效率和代码质量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值