美文网首页互联网科技程序员
Quarkus:一个 Kubernetes 原生 Java 框架

Quarkus:一个 Kubernetes 原生 Java 框架

作者: 撩课学院 | 来源:发表于2019-03-29 08:23 被阅读30次

    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() {
        return say.hello();
    }
    
    

    反应式风格:

    @Inject @Stream("kafka")
    Publisher reactiveSay;
    
    @GET
    @Produces(MediaType.SERVER_SENT_EVENTS)
    public Publisher stream() {
        return reactiveSay;
    }
    
    

    也可以使用 Quarkus 实现在无服务器环境中使用的函数,比如,下面是一个 AWS Lambda 的例子:

    public class HelloLambda implements RequestHandler {
    
        @Inject
        HelloGreeter greeter;
    
        @Override
        public String handleRequest(HelloRequest request, Context context) {
            return greeter.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:一个 Kubernetes 原生 Java 框架

        本文链接:https://www.haomeiwen.com/subject/epdkbqtx.html