QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

TOP 13 大最热开源微服务 Java 框架

  • 2019-01-04
  • 本文字数:2621 字

    阅读完需:约 9 分钟

TOP 13大最热开源微服务Java框架

本文列举了 13 大可在 JVM 上构建可靠轻量级微服务的 Java 框架


经过长期发展,Java 最终在服务器领域找到一席之地,不同芯片架构和操作系统对“一次编写,到处运行”的承诺很感兴趣。与此同时,JavaScript 一直在挑战 Java 的地位,前者因为高吞吐量和速度快接管了大批网络流量。Node.js 不仅提高了速度和资源效率,还简化了客户端和服务器运行代码的复杂度。


尽管竞争激烈,许多负责微服务架构开发的团队依旧在继续使用 Java,这可能有多方面原因,比如 Java 经过多年测试,Sun 创建了稳定的虚拟机,Oracle 大力培养和支持,用户使用习惯等。


本文列举了 Java 开发人员正在使用的 13 大开源项目,这些框架构成各地微服务架构基础。

Spring Boot

Java 一直在构建 Spring 应用程序,Spring Boot 是 Spring 的特定版本,通过对配置细节进行处理,Spring Boot 可以自动化微服务配置过程,其创建是为了自启动所有类型 Spring 项目,而不仅仅是微服务。一旦应用程序完成,Spring Boot 会混合在 Web 服务器中,并发出 JAR 文件,可以想象成原始 Docker 容器。


使用 Spring 开发微服务遵循与 Web 应用相同的 MVC 理念。该框架享有多年 Java 开发所构建的深层连接,包括所有主要和次要数据存储,LDAP 服务器以及 Apache Kafka 等消息传递工具集成,众多维护运行服务器集合的小功能,比如 Spring Vault,维护生产服务器所需密码等。

Eclipse MicroProfile

2016 年,Java Enterprise 社区决定清除 Java Enterprise Edition 中的部分内容,以便用户可使用经典部件构建简单微服务。在去掉大量库之后,社区保留了处理 REST 请求、解析 JSON 和管理依赖注入等功能,最终版本被称为 Eclipse MicroProfile,其特点是快速且简单。


从那时起,MicroProfile 社区就制定了一个协议,“每季度发布一次新版本,同时添加新代码以保持微服务平稳安全运行”。对于使用 Java EE 的人来说,开发过程和代码结构将非常熟悉,但无休止的配置麻烦已被去除。

Dropwizard

2011 年,Dropwizard 问世并开启 Java Enterprise 开发人员的视野,其提供非常简单的开发模型,用户可添加业务逻辑,并根据惯例配置其他内容。整个 JAR 文件非常苗条,并且可以快速启动。


Dropwizard 的最大限制可能是缺乏依赖注入,如果想使用依赖注入保持代码干净和松散耦合,用户需要自己添加库。与 Spring 不同,没有 Dropwizard 方法可以做到这一点。但是,Dropwizard 支持大多数功能,比如日志记录、健康检查和提供弹性代码。

WildFly Thorntail

Red Hat 用户使用灵活的配置工具构建 MicroProfile 版本,该框架最初被称为 WildFly Swarm,随后被重命名为 Thorntail。只需在 Thorntail 上指定需要功能,用户即可创建 Maven 构建文件,然后由 Maven 负责组装一切。


Thorntail 通过扫描代码检测主要组件,也可使用 BOM 文件覆盖。全部运行时,Thorntail 将删除不被使用的 Java 企业版并创建小型 JAR 文件,可以使用命令部署。这是另一种遵循 Java 企业版传统方法,而不保留沉重包袱的框架。

Helidon

Helidon 架构剔除了 Java Enterprise Edition,保留基于 servlet 的轻量级核心。在 Helidon 中,开发人员可使用 Netty 并添加代码进行路由和错误处理。它采用两种基本代码模型,即 SE 和 MP 版本。


Node.js 程序员会对 Helidon SE 非常熟悉,因为其具有由句点连接的长链函数调用。对于使用 JAX-RS 的 Java 程序员而言,Helidon MP 看起来会很熟悉,Helidon 集成了一些备受好评的工具,用于检查服务器运行状况或通过微服务跟踪数据流。

Cricket

Cricket 是一个快速 API 开发框架,虽然小,但包含相对丰富的功能,比如键值数据存储,以节省连接数据库和调度程序,控制重复的后台处理。没有其他依赖项增加复杂性或锁定,因此将代码添加到 Cricket 并启动独立微服务非常容易。

Jersey

开发 Web 服务的标准之一是用于 RESTful Web 服务的 Java API(又名 JAX-RS),这是一个已在 Jersey 框架中实现的通用规范。该方法在很大程度上取决于使用注释来指定路径映射和返回详细信息。解析参数和打包 JSON 其他内容,Jersey 均可处理。


Jersey 的主要优点是实现 JAX-RS 标准,部分开发人员也会将 Jersey 和 Spring Boot 结合在一起使用。

Play

体验 JVM 跨语言功能的最佳方式之一是用 Play 框架,这是与 Java 或其他 JVM 语言链接的 Scala 代码。该代码非常现代,具有异步、无状态模型等,不会使服务器过载,没有无休止的线程试图跟踪用户及会话数据。Play 有一些额外功能可用于充实网站,比如 OpenID、验证和文件上传支持。

Swagger

构建 API 可能看起来像编写侦听端口并提供答案的代码一样简单,但 Swagger 开发人员不会同意此说法。他们创建了名为 OpenAPI 的完整 API 规范语言,Swagger 团队提供将此规范转换为自动化测试和文档等的代码。


Swagger 配置文件对 API 非常简单,可用于实现并记录接口行为,提供工具测试在其下构建的代码,此外,提供 API 治理机制。Swagger 是 API 的生态系统,并且不局限于 Java。如果团队转移到 Node.js 或其他语言,则会有 Swagger Codegen 模块等待将 OpenAPI 规范转换为该语言的实现。

Restlet

框架之间的较大差异之一是与其他服务和库之间的连接数。Restlet 是可提供最大功能和连接集合的项目之一。为防微服务对邮件服务器接收 POP,IMAP 或者 SMTP, Restlet 集成了 JavaMail 库;为防构建大量文本索引和元数据,Restlet 集成了 Lucene 和 Solr。


Restlet 不需要使用 JSON,因为代码可以处理 XML、CSV、YAML 等多种文件格式,还可获得用于构建响应模板的多个不同选项。此外,Restlet 客户端允许在 Chrome 浏览器测试 API。

Squash

因为部件松散耦合且很难跟踪通过系统所有层的数据流,因此调试微服务一直是个难题。Squash 允许在 Kubernetes 集群运行代码中设置断点,在 IDE 接收所有数据,就好像本地运行代码一样。Squash 还集成了 Node.js 和 Python 运行时,以防微服务集合没有使用 Java 代码。

Telepresence

Telepresence 是另一个调试选择,可为远程 Kubernetes 集群微服务创建本地代理,对此服务的调用将转移到本地,可以在其中设置断点或执行本地计算机上可进行的任何操作。

Zipkin

Zipkin 用于在微服务上记录并关联事件,以便在问题通过机器集合时进行隔离和研究。Zipkin 有 Java 等至少六种语言实现版本,因此可处理多语言系统。不少框架已经通过某种形式集成 Zipkin,比如 Spring。


参考链接:


https://www.infoworld.com/article/3329944/java/13-java-frameworks-for-rock-solid-microservices.html


2019-01-04 08:0015478
用户头像
赵钰莹 极客邦科技 总编辑

发布了 892 篇内容, 共 664.2 次阅读, 收获喜欢 2689 次。

关注

评论 2 条评论

发布
用户头像
很多项目的简介真是简单啊,都没说清这个项目是干啥的
2019-01-04 09:59
回复
用户头像
Spring Boot可以的
2019-01-04 09:39
回复
没有更多了
发现更多内容

uniapp+若依 开发租房小程序

詹Sir

大前端

【混合云小知识】混合云四种形式简单说明

行云管家

云计算 公有云 私有云 混合云 云管理

教你用SQL进行数据分析

华为云开发者联盟

Python sql 数据分析 数据 BI 分析工具

【高并发】从源码角度深度解析线程池是如何实现优雅退出的

冰河

Java 并发编程 多线程 高并发 异步编程

制作 Flask 程序容器镜像

wong

Python flask k8s Dockerfile

基于MySQL binlog日志,实现Elasticsearch近实时同步实践

热爱java的分享家

Java 架构 程序人生 编程语言 经验分享

肝!Spring JDBC持久化层框架“全家桶”教程

热爱java的分享家

Java 架构 程序人生 编程语言 架构师

【等保】等保3.0是什么意思?有等保3.0吗?

行云管家

网络安全 等保 等级保护 等保2.0

一文读懂Hive数据存储格式

五分钟学大数据

11月日更

轻松搞懂MySQL的执行计划,再也不怕SQL优化了

华为云开发者联盟

MySQL 数据库 sql 执行计划 检索

一周信创舆情观察(11.8~11.14)

统小信uos

SpringBoot+WebSocket实时监控异常

热爱java的分享家

Java spring 架构 程序人生 编程语言

问题也许没有看上去那么简单

神策技术社区

神策数据

论文解读丨LayoutLM: 面向文档理解的文本与版面预训练

华为云开发者联盟

CV 预训练 LayoutLM模型 无标注 文档理解

Python量化数据仓库搭建系列1:数据库安装与操作

恒生LIGHT云社区

量化投资

鱼龙混杂的低代码市场,企业选型需关注哪些重点?

优秀

低代码 企业数字化转型

请说说RPC的一个请求的流程是怎么样的?

热爱java的分享家

Java 架构 程序人生 编程语言 经验分享

SCTL 涅槃重生:投入 RAL 的怀抱

SphereEx

Java 数据库 大前端 ShardingSphere SCTL

Python爬虫采集,中介网互联网网站排行榜, 样本数量:58341

梦想橡皮擦

11月日更

.NET6 引入Autofac

面向对象的猫

.net6 快速上手.net6

“阿里巴巴”再次出手,这份Github新开源303页Spring全家桶高级笔记,让你打开眼界

热爱java的分享家

Java 架构 面试 程序人生 编程语言

HBase shell get命令从二进制还原真实值

WindFlying

元数据管理在数据仓库的实践应用

大数据技术指南

11月日更

​Qt全球峰会2021中国站深入解读最新Qt 6.2长周期版本,助力企业数字化转型

低代码——不应该只是玩具

行云创新

云原生 低代码 开发 高效

dart系列之:元世界pubspec.yaml文件详解

程序那些事

flutter dart 程序那些事 11月日更

熵简技术谈 | 熵简科技在资管数据中台的探索与实践

熵简科技

数据挖掘 数据库 大数据 数据中台 数据分析

快速剪辑-助力度咔智能剪辑提效实践

百度Geek说

架构 后端

有一说一,阿里内部SpringBoot王者晋级之路全彩小册开源,让我开了眼

热爱java的分享家

Java 架构 面试 程序人生 编程语言

更改Apollo数据库为oracle

小鲍侃java

11月日更

想一个问题,在高并发中,如何部署奇数个节点?

热爱java的分享家

Java 架构 程序人生 编程语言 经验分享

TOP 13大最热开源微服务Java框架_编程语言_赵钰莹_InfoQ精选文章