88

Quarkus:一个 Kubernetes 原生 Java 框架

 5 years ago
source link: https://www.infoq.cn/article/QYNE5rQ_PucIZIsmkk4J?amp%3Butm_medium=referral
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

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 上自动伸缩微服务,而低内存利用率有助于优化微服务体系结构部署中的容器密度。同时,它还提供了更小的应用程序和容器镜像空间占用。

JnAJB3I.png!web

(图片来自: https://quarkus.io/)

按照设计,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


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK