Red Hat 发布了 Quarkus,这是一个为 GraalVM 和 OpenJDK HotSpot 量身定制的 Kubernetes 原生 Java 框架。Quarkus 的目标是使 Java 成为 Kubernetes 和无服务器环境中的领先平台,为开发人员提供统一的反应式和命令式编程模型。
Quarkus 利用 Java 开发人员使用的一系列库,如 Eclipse MicroProfile 和 Vert.x,带来了一个全栈框架。Quarkus 依赖注入基于 CDI,允许开发人员使用 JPA/Hibernate、JAX-RS/RESTEasy 等。此外,Quarkus 还包含一个扩展框架,第三方框架作者可以利用该框架对其进行扩展;这个扩展框架同时还编译成了一个 GraalVM 原生二进制文件。
RedHat 表示,Quarkus 提供了可观的运行时效率,比如快速启动,支持在容器和 Kubernetes 上自动伸缩微服务,而低内存利用率有助于优化微服务体系结构部署中的容器密度。同时,它还提供了更小的应用程序和容器镜像空间占用。
按照设计,Quarkus 完美地引入了命令式和反应式模型,旨在让熟悉命令式模型但不想学习新范式的 Java 开发人员以及采用云原生 / 反应式模型方法的开发人员快速采用。
命令式风格:
复制代码
@Inject SayService say; @GET @Produces(MediaType.TEXT_PLAIN) public String hello() { returnsay.hello(); }
反应式风格:
复制代码
@Inject@Stream("kafka") Publisher reactiveSay; @GET @Produces(MediaType.SERVER_SENT_EVENTS) public Publisher stream() { returnreactiveSay; }
也可以使用 Quarkus 实现在无服务器环境中使用的函数,比如,下面是一个 AWS Lambda 的例子:
复制代码
publicclassHelloLambdaimplementsRequestHandler{ @Inject HelloGreeter greeter; @Override publicStringhandleRequest(HelloRequest request, Context context){ returngreeter.greet(request.firstName, request.lastName); } }
Quarkus 被设计成少配置或无配置,其工作方式很直观。为此,开发人员可以用以下工具构建一个新项目:
复制代码
mvn io.quarkus:quarkus-maven-plugin:0.12.0:create / -DprojectGroupId=my-groupId / -DprojectArtifactId=my-artifactId / -DprojectVersion=my-version / -DclassName="org.my.group.MyResource"
Quarkus 还提供了“在线编码(Live Coding)”功能,使开发人员避免了编写代码→编译→部署→刷新浏览器→重复的枯燥过程。运行 mvn compile quarkus:dev,Quarkus 将在开发模式下启动。当它接收到 HTTP 请求时,它将保存该请求并检查是否更改了任何应用程序源文件。如果有,它将透明地编译更改的文件,重新部署应用程序,然后将 HTTP 请求发送给重新部署的应用程序。
Quarkus 似乎至少是云时代一个有趣的替代方案。在这个时代,容器、Kubernetes、微服务、函数即服务(FaaS)和云原生应用程序正在提供更高级别的生产力和效率。
要了解关于 Quarkus 的更多细节,请访问 quarkus.io 。想要开始使用 Quarkus 的开发人员可以查看入门指南或其他可用的指南。
查看英文原文: Quarkus, a Kubernetes Native Java Framework