专栏首页TECH flower云原生时代高性能Java框架—Quarkus(一)

云原生时代高性能Java框架—Quarkus(一)

——— Quarkus&GraalVM介绍、创建并启动第一个项目


Quarkus系列博文

  • Quarkus&GraalVM介绍、创建并启动第一个项目
  • 构建Quarkus本地镜像、容器化部署Quarkus项目
  • ...

Quarkus介绍

Quarkus 是一个为 Java 虚拟机(JVM)和原生编译而设计的全堆栈 Kubernetes 原生 Java 框架,用于专门针对容器优化 Java,并使其成为无服务器、云和 Kubernetes 环境的高效平台。

Quarkus 可与常用 Java 标准、框架和库协同工作,例如 Eclipse MicroProfile、Apache Kafka、RESTEasy(JAX-RS)、Hibernate ORM(JPA)、Spring、Infinispan、Camel 等。

Quarkus 的依赖注入解决方案基于 CDI(上下文和依赖注入),且包含一个扩展框架来扩展功能并将其配置、引导并集成到您的应用中。添加扩展就像添加依赖项一样容易;或者,您可以使用 Quarkus 工具。

此外也是引人注目的一个特点,它还向 GraalVM(一种通用虚拟机,用于运行以多种语言(包括 Java 和 JavaScript)编写的应用)提供正确信息,以便对应用进行原生编译。

Rad Hat列出了一下清单来表明使用Quarkus的好处:检查清单

Quarkus与传统Java框架对比

Quarkus与传统技术栈对比

来自官方的一张图,展示了使用Quarkus框架开发项目和使用传统框架开发的一些运行时数据明细对比,可以看到Quarkus项目在JVM中运行时所消耗的内存和接口响应能力要明显好于传统的Java技术栈。而将Quarkus编译成本地可执行文件(本地镜像)之后,其优势可以说非常明显了。

GraalVM简介

GraalVM是一种高性能的虚拟机,它可以显著的提高程序的性能和运行效率,非常适合微服务。其设计初衷是实现可以运行不同语言(Java、JavaScript、基于LLVM的语言(例如C和C ++)以及其他动态语言)编写的应用程序。它消除了不同编程语言之间的隔阂,并实现了多语言共享运行时的互操作性。它可以独立运行,也可以在OpenJDK,Node.js或Oracle数据库的上下文中运行。

对于Java应用程序,GraalVM可以带来很多有价值的好处:更快地运行它们,通过脚本语言(JavaScript, R, Python...)提供可扩展性或创建提前编译的本机映像(native-image)。

更多关于GraalVM的信息可参考:此篇文章。

GraalVM安装

本文我们使用SDKMAN来安装GraalVM。SDKMAN是一款用于在大多数基于Unix的系统上管理多个软件开发套件的并行版本的工具。它提供了一个方便的命令行界面(CLI)和API,用于安装,切换,删除和列出候选人。它以前被称为Groovy enVironment Manager (GVM),受到了非常有用的RVM和rbenv工具的启发,该工具在Ruby社区中广泛使用。

安装SDKMAN

运行如下命令进行安装:

$ curl -s "https://get.sdkman.io" | bash
$ source "$HOME/.sdkman/bin/sdkman-init.sh"	

运行如下命令,验证是否已安装ADKMAN:

$ sdk version

安装GraalVM

运行如下命令:

$ sdk list java

可以看到SDKMAN列出了所支持的所有Java发行版

我们找到GraalVM的发行版

截至编写本文时,GraalVM的最新版本为20.1.0.r11-grl,所以我们会安装此版本。运行如下命令安装GraalVM:

$ sdk install java 20.1.0.r11-grl

至此,GraalVM安装完毕!我们可以运行如下命令来判断GraalVM是否已安装:

$ java -version

创建项目

我们有多种方式创建Quarkus项目

使用Intellij IDEA创建Quarkus项目

点击菜单栏File>New>Project... 创建新项目

点击Next,并填写适当的信息,Next>Next...,创建完毕。

使用Maven命令行创建Quarkus项目

运行如下命令,创建Quarkus项目:

mvn io.quarkus:quarkus-maven-plugin:1.6.0.Final:create \
    -DprojectGroupId=org.acme \
    -DprojectArtifactId=getting-started \
    -DclassName="org.acme.getting.started.GreetingResource" \
    -Dpath="/hello"
cd getting-started

至此,创建项目完毕!

启动项目

我们使用IDEA打开项目

Quarkus并没有类似Spring Boot、Helidon之类框架一样的启动类,我们需要通过运行Maven命令来启动项目。

在IDEA控制台运行如下命令来启动项目:

./mvnw compile quarkus:dev

启动成功!

当然每次运行命令行会显得不便,我们可以通过如下配置来配置项目快捷启动:

点击左上角"+"图标添加一个Maven配置如左边栏,在右边栏中的Command line中填入"compile quarkus:dev",点击OK。

此时可以点下下图所示图标来便捷启动项目

运行测试

打开项目中的测试类,看到如下代码:

@QuarkusTest  //1
public class ExampleResourceTest {
    @Test
    public void testHelloEndpoint() {
        given()
            .when().get("/hello")
            .then()
            .statusCode(200) //2
            .body(is("hello"));
    }
}
  1. 通过使用@QuarkusTest注解运行程序,可以指示JUnit在测试之前启动应用程序。
  2. 检查HTTP响应状态代码和内容。

默认情况下,测试将在端口8081上运行,以免与正在运行的应用程序冲突。Quarkus自动将RestAssured配置为使用此端口。如果要测试其他路径,则可以使用@TestHTTPResource注解将被测试的URL直接注入到测试类的字段中。该字段的类型可以是字符串,URL或URI。我们需要为该注解指定测试路径的值。例如,如果我要测试映射到/myservlet的Servlet,只需在测试中添加以下内容:

@QuarkusTest  
public class ExampleResourceTest {
    @TestHTTPResource("/myservlet")
    URL testUrl;

    @Test
    public void testHelloEndpoint() {
        given()
            .when().get(testUrl)
            .then()
            .statusCode(200) 
            .body(is("hello"));
    }
}

可以通过在项目配置文件中配置quarkus.http.test-port属性控制测试端口。Quarkus还创建了一个名为test.url的系统属性,该属性值将被设置成基础测试URL(BasePath)。

总结

我们进入了云原生、微服务的时代,我们告别了大型单体应用的庞大和复杂,并且收获了微服务带来的极大的好处 。但是一些问题也开始接踵而至。随着微小服务的增多,曾经在单个应用上发生的多余无用依赖、Java项目与生俱来的启动过程缓慢、JIT优化问题扩散到了每个微服务上面。而且传统的Java EE规范并没有微服务的模式解决方案,问题很迫切需要解决。幸运的事,随着Quarkus、Helidon等等一些新型Java开发框架的出现缓解了这个局面(以及目前Spring生态也开始了对GraalVM的大力支持),他们使Java变得更加本地化,不管是项目的体量方面还是资源消耗和运行效率方面都有显著提升。

本文分享自微信公众号 - TECH flower(tech-flower),作者:东溪陈姓少年

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-07-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 云原生时代高性能Java框架—Quarkus(二)

    上一篇文章主要介绍了Quarkus以及给Quarkus提供“神力”的Java虚拟机GraalVM,并演示了如何安装GraalVM以及Quarkus的初步用法。本...

    东溪陈姓少年
  • 在 Kubernetes 中优化 Java 无服务器功能——1

    由于运行数千个应用程序 pod 的费用以及使用更少的工作节点和其他资源来节省成本,在Kubernetes 中更快的启动和更小的内存占用总是很重要的。在 Kube...

    施主-借个火
  • Quarkus是Java的未来吗?

    专为OpenJDK HotSpot和GraalVM量身定制的Kubernetes本机Java堆栈,采用最佳Java库和标准精制而成。

    IT大咖说
  • 有了服务网格,这些Java微服务框架你还会选吗?

    来源:分布式实验室 译者:黄亮 至今,Java仍旧是用来构建Web应用的最流行编程语言之一 —— 但是它不得不面对诸如Go,Python和TypeScrip...

    灵雀云
  • Red Hat 开源 Quarkus 1.0:Java 已为云原生时代做好了准备

    最近,Red Hat 开源了 Quarkus 1.0 项目,这标志着其在为 Kubernetes 提供 Java 实例上取得了一个里程碑。

    Java帮帮
  • 2020年你将会选择哪个微服务框架?

    截至2020年,Java仍然是构建Web应用程序的最流行的编程语言之一,尽管它必须面对来自Go,Python和TypeScript等新型语言的激烈竞争。

    用户1516716
  • Quarkus 云原生java开发框架1: hello world

    既然是一个 java 应用,那应该是无需什么准备的,jdk,maven 这些都有了。

    谢正伟
  • 5 个开源的 Java IDE 工具

    通过简化程序员的工作,Java 框架可以使他们的生活更加轻松。这些框架是为了在各种服务器环境上运行各种应用程序而设计开发的;这包括解析注解、扫描描述符、加载配...

    用户8639654
  • Quarkus 云原生java开发框架2: 远程调用

    本篇主要介绍了 Quarkus 中的远程调用,项目的结构采用了传统的微服务模式。演示了如何编写符合 istio 的 Quarkus java 程序。

    谢正伟
  • 在 2021 年你需要知道 Quarkus 些什么?

    在云上发布服务部分是为了通过简单可靠的方式为用户和开发者提供对这些服务的便捷访问。与在线应用对接的最流行的方法之一是通过应用编程接口(API),这是一个花哨的术...

    用户8639654
  • 5 个开源的 Java IDE 工具

    通过简化程序员的工作,Java 框架可以使他们的生活更加轻松。这些框架是为了在各种服务器环境上运行各种应用程序而设计开发的;这包括解析注解、扫描描述符、加载配置...

    用户8639654
  • 炒币不是未来,云原生才是致胜法宝

    最近币圈极度疯狂,上到精英阶层,下到大爷大妈,全都在往里挤,地铁站随便瞟一眼就能看到有人在打开火币 app。各种动物币满天飞,光狗币就有好几种,大狗子、二狗子、...

    米开朗基杨
  • Quarkus初体验

    Quarkus是为GraalVM和HotSpot量身定制的Kubernetes Native Java框架,由最佳的Java库和标准精心打造而成。Quarkus...

    是小张啊喂
  • 3月Github最热门的10个Java开源项目

    •Github 地址: https://github.com/Snailclimb/JavaGuide[1]•Star: 32.9k (6,196 stars ...

    乔戈里
  • Spring Boot 快速迁移至 Quarkus

    Quarkus 是一个目前非常火的 Java 应用开发框架,定位是轻量级的微服务框架。,Quarkus 提供了优秀的容器化整合能力,相较于传统开发框架(Spri...

    冷冷
  • Spring Native与WebFlux一样注定昙花一现?

    现如今,多少新的概念或产品昙花一现都不足为奇。我们对于一个未知的事物都会感到好奇以及充满期待,就像你突然得知自己要当父亲了,对孩子的降临充满期待一样,也没有哪个...

    Java艺术
  • 惊呆了,Spring Boot居然这么耗内存!

    Spring Boot总体来说,搭建还是比较容易的,特别是Spring Cloud全家桶,简称亲民微服务,但在发展趋势中,容器化技术已经成熟,面对巨耗内存的Sp...

    芋道源码
  • 『Spring Boot 2.4新特性』减少95%内存占用

    GraalVM 是一种高性能的虚拟机,它可以显著的提高程序的性能和运行效率,非常适合微服务。最近比较火的 Java 框架 Quarkus 默认支持 GraalV...

    冷冷
  • 小宇宙爆发!Spring Boot 新特性:节省95%内存占用!

    GraalVM[1] 是一种高性能的虚拟机,它可以显著的提高程序的性能和运行效率,非常适合微服务。最近比较火的 Java 框架 Quarkus[2] 默认支持 ...

    macrozheng

扫码关注云+社区

领取腾讯云代金券