在 Helidon 伞项目下,甲骨文推出了基于虚拟线程(JEP 425)的新微服务框架 Helidon Níma。它是完全从头构建的,以实现易于使用的编程模型,并具有出色的性能。该技术的预览版已经伴随 Helidon 4.0.0-ALPHA1 版本发布,对最新 Java 技术感兴趣人可以对此进行评估。但是,它尚未达到生产环境就绪状态。
开发人员可以通过 Helidon MP 或 Helidon SE 使用常规的 Helidon 框架达到一定的吞吐量,但是如果应用需要更高的性能,他们唯一能做的就是采用基于反应式的服务。但值得一提的是,编写、维护和调试基于反应式的服务更具挑战性。
Helidon Níma 使用虚拟线程来解决这个问题,因为基于虚拟线程,阻塞的成本是很低的,所以我们可以创建数以百万计的虚拟线程。因此,这提供了一个恒定的、低开销的、高并发的服务器,同时能够保持阻塞式的线程模型。开发人员通过最小的支撑功能就可以编写简单、可调试和易维护的代码。请考虑如下的样例:
阻塞式代码
private void one(ServerRequest req, ServerResponse res) {
String response = callRemote(client());
res.send(response);
}
反应式代码
private void one(ServerRequest req, ServerResponse res) {
Single<String> response = client.get()
.request(String.class);
response.forSingle(res::send)
.exceptionally(res::send);
}
阻塞式代码和反应式代码都能完成相同的目标,但是,反应式代码对认知的要求更高,学习曲线更陡峭,并且难以维护。正如甲骨文的架构师 Tomas Langer 在最初的博客文章中所说的那样,在较为复杂的用例中,这一点会更明显。
按照 Langer 的说法,Heldion Níma 主要的关注点是性能,它也的确产生了一定的效果,如下图所示。
这个 Alpha 版本支持如下的协议:
支持 pipelining 的 HTTP/1.1:客户端和服务器端。
HTTP/2 服务器端(原型状态,包含已知的问题)
gRPC 服务器端(原型状态,包含已知的问题)
WebSocket 服务器端(原型状态)
除此之外,它还支持如下的特性:
跟踪:使用现有的 Helidon 跟踪实现,比如 Jaeger 或 Zipkin
静态内容:来自类路径或文件系统
跨域资源共享(CORS)
访问日志
可观测性端点(健康状态、应用信息、配置)
容错(舱壁、断路器、重试和超时特性)
HTTP/1.1 客户端
测试
在这些特性之上,它还使用了新的 Java 语言特性,如 密封类(sealed classes) 和增强的 switch 表达式。
Helidon Níma 是一个完全开源的框架,是 Helidon 代码库的一部分。尽管 Helidon 项目是基于 Netty 的,但是甲骨文公司的软件开发人员 Dmitry Aleksandrov 在他的博客文章中提到:
Helidon Níma 网络服务器计划在 Helidon 生态系统中取代 Netty。它也可以被其他框架以嵌入式 Web 服务器组件的形式使用。
希望评估 Helidion Níma 的开发人员可以参阅 Tomas Langer 的初始博客文章和托管在 GitHub 仓库的源代码。
原文链接:
https://www.infoq.com/news/2022/09/introducing-helidon-nima/
相关阅读:
https://www.infoq.cn/article/0AXykmqvf5lHZsEQtjBp
点击底部阅读原文访问 InfoQ 官网,获取更多精彩内容!
钉钉总裁称非常讨厌红点和 DING 消息;Mozilla 控诉苹果、谷歌和微软锁定浏览器;特斯拉上海工人薪酬曝光:到手七八千|Q 资讯