Java云原生+quarkus

一、Java如何实现云原生应用?

传统的 Java 框架(如 Spring Boot)虽然功能强大,但在云原生场景下可能显得笨重。以下是一些更适合云原生的轻量级框架:

Quarkus(推荐)

  • 专为云原生和 Kubernetes 设计的 Java 框架。
  • 支持 GraalVM 原生镜像,启动速度快,内存占用低。
  • 与 Kubernetes、OpenShift 等云原生平台深度集成。

Micronaut

  • 另一个轻量级框架,专注于快速启动和低内存占用。
  • 支持 GraalVM 原生镜像。
  • 提供了对微服务、函数计算和云原生环境的支持。

二、Java 云原生实战

接下来,我们将从零开始,开发一个简单的Java云原生应用,并将其打包发布到本地Docker。

环境准备

  • 操作系统:Windows 11
  • 开发工具:IntelliJ IDEA
  • 框架:Quarkus
  • 容器工具:Docker Desktop for Windows

步骤 1:创建Quarkus项目

  1. 打开IntelliJ IDEA,点击"New Project"。
  2. 选择"Quarkus"作为项目类型,点击"Next"。
  3. 输入项目名称(例如quarkus-demo-mvn),选择项目路径,点击"Create"。
  4. 在依赖选择页面,勾选"REST"",点击"Finish"。

完成后可以看到目录结构如下,除了多了个 docker 目录其它和 springboot 是一样的。

后面会具体介绍 docker 目录下几个文件的区别。

步骤 2:编写代码

  1. src/main/java目录下,找到自动生成的ExampleResource.java文件。

  2. 修改代码如下:

    package com.hanko;

    import jakarta.ws.rs.GET;
    import jakarta.ws.rs.Path;
    import jakarta.ws.rs.Produces;
    import jakarta.ws.rs.core.MediaType;

    @Path("/hello")
    public class ExampleResource {

    复制代码
     @GET
     @Produces(MediaType.TEXT_PLAIN)
     public String hello() {
         return "Hello from Quarkus REST";
     }

    }

可以看到代码和我们以前不一样的地方就是:

  • 没有引用 spring 相关依赖
  • 注解使用的与 springboot 不一样
  • 可以看到它引用的都是 jakarta.ws.rs 的依赖也就是JAX-RS(Java API for RESTful Web Services)它是 Java 中用于开发和实现 RESTful Web 服务 的标准 API。它是 Jakarta EE(原 Java EE)的一部分,提供了一套基于注解的编程模型,使得开发者可以轻松地将 Java 类暴露为 RESTful 资源。
  • quarkus 项目没有 SpringBootApplication 注解的启动类

步骤 3:本地运行

  1. 一般 IDEA 创建的项目在 IDEA 最上面会有 quarkus logo 点击小三角就可以启动项目。
  2. 打开浏览器,访问http://localhost:8080/,你会看到页面显示"Hello, Quarkus!"。
  1. 点/hello 也就是我们代码中实现的 rest 服务

p.s. quarkus 项目还有个比较优秀的功能就是默认就支持热加载,我们修改代码后不需要像 springboot 项目一样手动重启才生效。

修改代码后,在浏览器访问服务时,到达代码时就会触发热加载,此次热加载启动只花了 0.429 秒。

关于启动这块,还有没有其它的启动方式呢?当然通过命令行或 maven 都是可以的,如

quarkus:dev

步骤 4:打包 quarkus 项目

一般打包为 quarkus 项目要分成使用本地 GraalVM 与不使用本地 GraalVM

  • 使用本地GraalVM

    ./mvnw package -Dnative
    #mvn或mvnw都可以打包,使用mvnw还需要执行mvn wrapper:wrapper安装

这种比较麻烦的就是安装GraalVM 与Visual Studio。

GraalVM 的 native-image 工具依赖于 Visual Studio 的 C++ 编译器 (cl.exe) 和相关的构建工具。

就是还需要安装这些,安装完还需要配置 include、lib 环境变量。

  • 不使用本地GraalVM

Quarkus 会在 Docker 容器内完成所有操作

这种方式就简单多了,把本地可远程 docker 启动后,在 idea 里配置好

通过命令行

复制代码
./mvnw package -Dquarkus.container-image.build=true

如果你不想用命令行的话也可以选择使用 idea 来打包,就是直接使用生命周期中的 package

至于-Dquarkus.container-image.build=true 这个参数就可以放到项目中的 pom.xml 中去

pom.xml

复制代码
<properties>
    <skipITs>true</skipITs>
    <quarkus.native.container-build>true</quarkus.native.container-build>
    <quarkus.native.enabled>true</quarkus.native.enabled>
</properties>

就可以直接打包好了

可以看到我已经打包完成,就是这个文件。看到这个 xx-runner 文件就说明已经成功了

步骤 5:生成Docker镜像

这时就要使用项目中的几个 dockerfile 文件

  • Dockerfile.jvm 适合传统的 Java 应用,兼容性好,构建速度快。
  • Dockerfile.native 适合云原生场景,启动速度快,内存占用低。
  • Dockerfile.native-microDockerfile.native 的基础上进一步优化了镜像大小和安全性,适合对容器化部署有更高要求的场景。

p.s. 这几个文件中的配置是直接 copy target 目录文件,所以我们要把 docker 目录中的这几个文件先拷贝到项目的根目录下,如上图。

打镜像时,直接在文件上右键运行就可以了,当然你也可以修改一下配置,比如给镜像增加个名称

这就是三个 Dockerfile 配置文件对应生成的 docker 镜像文件

可以看到传统的大小为 413M,而原生的可以达到 79M,缩小 5 倍多。之前很多人抱怨 springboot 太大,打成 docker 就更大了,这回 quarkus 成为你们的福音了。

我们再来启动 demo-native-micro 镜像试试,点击小三角后,展开设置界面设置个宿主机的端口

已经启动了

访问方式,应用正常

到这里就完成了。

通过这个教程,我们从零开始创建了一个简单的Java云原生应用,并将其打包发布到本地Docker。整个过程非常简单,但涵盖了云原生开发的核心步骤:选择轻量级框架、编写代码、容器化部署。

我是栈江湖,如果你喜欢此文章,不要忘记点赞+关注

相关推荐
耀耀_很无聊24 分钟前
02_使用 AES 算法实现文件加密上传至阿里云、解密下载
java·spring boot·算法·阿里云·云计算·aes·oss
GalaxySpaceX1 小时前
Hibernate-Core (CVE-2020-25638)
java·spring·hibernate
景天科技苑1 小时前
【Rust通用集合类型】Rust向量Vector、String、HashMap原理解析与应用实战
开发语言·后端·rust·vector·hashmap·string·rust通用集合类型
阿沁QWQ1 小时前
友元函数和友元类
开发语言·c++
小钻风巡山3 小时前
springboot 视频分段加载在线播放
java·spring boot·后端
不会写代码的女程序猿3 小时前
废品回收小程序:全链路数字化解决方案,赋能绿色未来
java·小程序·微信小程序定制开发
小黑随笔3 小时前
【Golang玩转本地大模型实战(一):ollma部署模型及流式调用】
开发语言·后端·golang
江沉晚呤时3 小时前
Redis缓存穿透、缓存击穿与缓存雪崩:如何在.NET Core中解决
java·开发语言·后端·算法·spring·排序算法
achene_ql3 小时前
缓存置换:用c++实现最近最少使用(LRU)算法
开发语言·c++·算法·缓存
hunandede3 小时前
av_dict_get,av_dict_set,av_dict_set_int
java·前端·javascript