一、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项目

- 打开IntelliJ IDEA,点击"New Project"。
- 选择"Quarkus"作为项目类型,点击"Next"。
- 输入项目名称(例如
quarkus-demo-mvn
),选择项目路径,点击"Create"。 - 在依赖选择页面,勾选"REST"",点击"Finish"。
完成后可以看到目录结构如下,除了多了个 docker 目录其它和 springboot 是一样的。

后面会具体介绍 docker 目录下几个文件的区别。
步骤 2:编写代码
- 在
src/main/java
目录下,找到自动生成的ExampleResource.java
文件。 - 修改代码如下:
kotlin
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:本地运行

- 一般 IDEA 创建的项目在 IDEA 最上面会有 quarkus logo 点击小三角就可以启动项目。
- 打开浏览器,访问
http://localhost:8080/
,你会看到页面显示"Hello, Quarkus!"。

- 点/hello 也就是我们代码中实现的 rest 服务

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

修改代码后,在浏览器访问服务时,到达代码时就会触发热加载,此次热加载启动只花了 0.429 秒。
关于启动这块,还有没有其它的启动方式呢?当然通过命令行或 maven 都是可以的,如
quarkus:dev

步骤 4:打包 quarkus 项目
一般打包为 quarkus 项目要分成使用本地 GraalVM 与不使用本地 GraalVM
- 使用本地GraalVM
bash
./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 里配置好

通过命令行
ini
./mvnw package -Dquarkus.container-image.build=true
如果你不想用命令行的话也可以选择使用 idea 来打包,就是直接使用生命周期中的 package

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

pom.xml
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-micro
在Dockerfile.native
的基础上进一步优化了镜像大小和安全性,适合对容器化部署有更高要求的场景。
p.s. 这几个文件中的配置是直接 copy target 目录文件,所以我们要把 docker 目录中的这几个文件先拷贝到项目的根目录下,如上图。
打镜像时,直接在文件上右键运行就可以了,当然你也可以修改一下配置,比如给镜像增加个名称

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

可以看到传统的大小为 413M,而原生的可以达到 79M,缩小 5 倍多。之前很多人抱怨 springboot 太大,打成 docker 就更大了,这回 quarkus 成为你们的福音了。
我们再来启动 demo-native-micro 镜像试试,点击小三角后,展开设置界面设置个宿主机的端口

已经启动了

访问方式,应用正常

到这里就完成了。
通过这个教程,我们从零开始创建了一个简单的Java云原生应用,并将其打包发布到本地Docker。整个过程非常简单,但涵盖了云原生开发的核心步骤:选择轻量级框架、编写代码、容器化部署。
我是栈江湖,如果你喜欢此文章,不要忘记点赞+关注!