Spring Boot 4 重磅特性解析:Java 开发者必看的 6 大升级,附实战案例!

Spring Boot 4 重磅特性解析:Java 开发者必看的 6 大升级,附实战案例!

Java 生态又迎大更新!基于 Spring Framework 7 构建的 Spring Boot 4,不仅强制拥抱 Java 21+,更在性能、云原生、开发效率上带来颠覆性变化。今天用「特性 + 案例 + 效果」的方式,带你吃透这些能直接落地的新能力👇

📝 Powered by Moshow 郑锴 | 更多技术干货:https://zhengkai.blog.ZEEKLOG.net/

🔹 一、基础环境大升级:Java 21 成刚需,旧组件集体焕新

Spring Boot 4 彻底告别 Java 17 及以下版本,全面适配 Java 21 LTS 的新特性,同时对底层依赖做了「大清洗」:

  • ✅ 强制要求:Java 21+(推荐 Java 25)、Kotlin 2.2+
  • ✅ 核心依赖升级:Spring Security 7.0、Hibernate 7.1、Jackson 2.20
  • ❌ 弃用清单:Undertow 容器、JUnit 4、XML 配置、Spring JCL

实战注意:用jdeps命令快速排查第三方库兼容性:

jdeps --jdk-internals target/your-project.jar 

(出现JDK internal API警告的库需优先升级)

🔹 二、虚拟线程普及:一行配置,高并发吞吐量暴涨 10 倍

Java 21 的虚拟线程(Loom 项目)终于在 Spring Boot 4 中「开箱即用」,无需手动封装线程池,IO 密集型场景直接起飞!

🌟 核心特性

  • 自动适配:HTTP 客户端、数据库连接等阻塞操作默认跑在虚拟线程
  • 极简配置:仅需一行开启所有优化

📝 代码案例

# application.properties 开启虚拟线程 spring.threads.virtual.enabled=true 

// 高并发接口自动享用虚拟线程 //📝 Powered by Moshow 郑锴 | 更多技术干货:https://zhengkai.blog.ZEEKLOG.net/ @GetMapping("/batch-fetch-users") public List<UserDTO> batchFetch() { // 并行请求自动分配虚拟线程,无线程池OOM风险 return List.of("1001", "1002", "1003") .parallelStream() .map(userId -> userFeignClient.getUser(userId)) // IO阻塞操作 .toList(); } 

📊 性能对比

场景Spring Boot 3(JVM 线程)Spring Boot 4(虚拟线程)
并发请求数1000 QPS8000 QPS
内存占用450MB85MB
接口响应时间(P99)800ms120ms

🔹 三、原生镜像「零配置」:启动快如闪电,Serverless 狂喜

Spring Boot 4 把 GraalVM 原生镜像从「实验功能」升级为「官方标配」,无需额外引入spring-native模块,编译后启动时间缩短 80%+!

🌟 核心优势

  • 百毫秒启动:0.08 秒完成应用初始化(对比 JVM 的 2.1 秒)
  • 极致轻量:内存占用 < 100MB,容器部署体积减少 60%
  • 适配场景:Serverless 函数、边缘计算、低延迟金融系统

📝 实操步骤

https://docs.springframework.org.cn/spring-boot/how-to/native-image/developing-your-first-application.html

        1.要使用 Maven 构建本机镜像容器,您应确保 pom.xml 文件使用 spring-boot-starter-parent 和 org.graalvm.buildtools:native-maven-plugin。您应该有一个类似于此的 <parent> 部分

<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>4.0.0</version> </parent>

此外,您在 <build> <plugins> 部分应包含以下内容

<plugin> <groupId>org.graalvm.buildtools</groupId> <artifactId>native-maven-plugin</artifactId> </plugin>

spring-boot-starter-parent 声明了一个 native 配置文件,该配置文件配置了创建本机镜像所需的执行。您可以使用命令行上的 -P 标志激活配置文件。

        2.编译原生镜像:

./mvnw native:compile 

        3. 直接运行可执行文件:

./target/your-project # 无需JRE,双击启动 

🔹 四、API 版本控制:告别 URL 冗余,优雅兼容多版本接口

以前用/api/v1/user/api/v2/user区分版本的方式太繁琐?Spring Boot 4 新增原生版本控制注解,支持 3 种版本传递方式:

📝 代码案例

@RestController @RequestMapping("/api/user") public class UserController { // 版本1:兼容旧客户端 @GetMapping(version = "1") public UserV1 getUserV1(Long id) { return userService.getV1Data(id); } // 版本2:提供新字段 @GetMapping(version = "2") public UserV2 getUserV2(Long id) { return userService.getV2Data(id); } } 

🚀 调用方式(3 选 1)

  1. 请求头:X-API-Version: 2
  2. 请求参数:/api/user?id=1001&version=2
  3. 路径变量:/api/user/v2/1001(需额外配置路径匹配)

🔹 五、可观测性「全家桶」:埋点零代码,监控全自动化

集成 Micrometer 2 + OpenTelemetry,实现「指标、链路、日志」三位一体,运维不用再追着开发要埋点:

🌟 核心升级

  • 新增/metrics/v2端点:支持 OpenTelemetry 标准格式
  • 日志结构化:默认输出 JSON 格式,直接对接 ELK/Loki
  • 自动集成:gRPC 健康检查、Trace ID 日志注入

📝 配置示例

management: endpoints: web: exposure: include: "*" # 暴露所有监控端点 tracing: sampling: probability: 1.0 # 100%链路采样 metrics: export: otlp: enabled: true endpoint: http://otel-collector:4317 # 对接Prometheus 

📱 效果展示

请求后自动生成的 JSON 日志(含 Trace ID):

{ "timestamp":"2025-10-12T19:50:00", "traceId":"4f8d8a9e-75a1-4b3c-9d2e-8f7c6a5b4d3e", "level":"INFO", "message":"用户查询成功", "userId":"1001" } 

🔹 六、Starter 模块化:依赖瘦身 30%,按需搭配不臃肿

根据搜索结果和官方公告,Spring Boot 4.0 确实对 Starter 进行了一项核心的简化,名为 Starter合理化调整,但它采取的方式并非之前传闻的“核心+可选组件”的物理包拆分,而是基于全面模块化重构的依赖管理优化

核心变化:从“粗放打包”到“精确模块”

这项调整是为了配合 Spring Boot 4.0 的全面模块化重构(将原有大型单体结构拆分为数十个独立模块)。其目的是让依赖关系更清晰、职责更明确,从而解决你担心的“引入一个Starter带一堆无用依赖”的臃肿问题。

特性维度Spring Boot 3.x 及更早模式Spring Boot 4.0 的优化方向
设计思路“一站打包”式依赖管理。精细化模块化,按功能划分。
依赖粒度一个Starter可能捆绑多个相关功能,依赖较粗。将大型功能拆分为独立的、更细粒度的模块,如 spring-boot-webmvc
Starter角色作为依赖集合的入口。Starter本身进行“合理化调整”,成为更精准的模块化依赖组合器,职责更明确。

🚨 升级避坑指南 & 总结

  1. 优先升级组件:Undertow 用户需切换为 Tomcat 11 + 或 Jetty 12.1+
  2. 兼容性检查:用 Spring Boot Migration 工具扫描项目:./mvnw spring-boot:migrate
  3. 核心价值:Spring Boot 4 不是简单的版本迭代,而是为「Java 云原生」打下基础 —— 虚拟线程解决并发、原生镜像适配 Serverless、可观测性对接云平台。
  4. 📝 Powered by Moshow 郑锴 | 更多技术干货:https://zhengkai.blog.ZEEKLOG.net/

Read more

在Windows11系统上配置interl Realsense D435i深度相机+Python

在Windows11系统上配置interl Realsense D435i深度相机+Python

一、产品介绍 Intel RealSense D435i是英特尔公司推出的一款消费级深度相机,它的主要构成如下图所示。 主要包含一个RGB相机、两个红外相机以及一个红外发射器,此外还有一个IMU单元(这也就是D435i和D435的区别,i就表示imu)。简单来说它的深度成像原理是主动立体红外成像,不是传统意义上理解的双目RGB相机成像,这点需要注意一下。 有了深度图(3D点云)和对应的RGB影像,因此也就很容易获得RGB-D点云了。因此从输出的角度而言,D435i可以看做是一个RGB-D传感器相机。后续可以搭配ORB-SLAM中RGB-D的模式进行使用。当然,也可以只用单目RGB影像,以单目SLAM模式运行,或者单目结合IMU,以Mono-Initial模式运行。唯一不能运行的是双目RGB模式(因为两个红外相机是单通道的)。当然我们可以获取双目的红外影像,以此作为输入,进行双目SLAM,结果也是类似的。因此可以看出,D435i是一个比较“全能”的传感器,从单目、单目+IMU、双目、双目+IMU、RGB-D都可以使用。 对于它的一些技术上的参数,这里也简单列举一下: * 深度技

By Ne0inhk
【C++ 函数模板】—— 模板参数推导、实例化策略与编译优化

【C++ 函数模板】—— 模板参数推导、实例化策略与编译优化

欢迎来到ZyyOvO的博客✨,一个关于探索技术的角落,记录学习的点滴📖,分享实用的技巧🛠️,偶尔还有一些奇思妙想💡 本文由ZyyOvO原创✍️,感谢支持❤️!请尊重原创📩!欢迎评论区留言交流🌟 个人主页 👉 ZyyOvO 本文专栏➡️C++ 进阶之路 各位于晏,亦菲们请看 * 引言 * 函数模板的概念 * 函数模板的匹配原则 * 函数模板的底层原理 * 模板的编译阶段 * 模板实例化 * 编译器与链接器的协作 * 编译器的工作流程 * 前端编译阶段 * 模板实例化阶段 * 后端编译阶段 * 函数模板总结 * 写在最后 引言 点击快速复习 👉:【C++ 函数重载】—— 现代编译技术下的多态表达与性能优化 上篇文章我们讲到C++的函数重载,包括函数重载的条件,原理以及一些易错事项,那么本文我们为大家介绍C++中泛型编程的主要方式——模板。 在 C++ 中,模板(Template)是一种强大的编程特性,它允许程序员编写与类型无关的代码,实现代码的复用和泛型编程。 如同模具一样,

By Ne0inhk
基础算法:滑动窗口_python版本

基础算法:滑动窗口_python版本

能使用滑动窗口的题,基本都需要数字为正整数,这样才能保证滑入一个数字总和是增加的(单调性) 一、209. 长度最小的子数组 * 思路: 已每个位置为右端点,依次加大左端点,最短不满足 sum(num[left,right]) < target的。 * 代码: classSolution:defminSubArrayLen(self, target:int, nums: List[int])->int: n =len(nums) ans = n +1# 也可以写 inf s = left =0for right, x inenumerate(nums):# 枚举子数组右端点 s += x while s >

By Ne0inhk
纯C++手撸PP-OCRv5文字识别!不依赖OpenCV,从零到跑通全流程

纯C++手撸PP-OCRv5文字识别!不依赖OpenCV,从零到跑通全流程

纯C++手撸PaddleOCR PP-OCRv5文字识别!不依赖OpenCV,从零到跑通全流程 你是不是也遇到过这种情况:想在C++项目里加个OCR功能,结果光装OpenCV就折腾半天?今天教你零OpenCV依赖,用Paddle Inference + stb_image,纯C++实现PP-OCRv5文字识别全流程(检测+识别),代码可直接跑! 一、效果先行 cd /home/michah/桌面/paddle_inference && ./build/ocr_demo build/640.png --text-only cd /home/michah/桌面/paddle_inference && ./build/ocr_demo build/640.png

By Ne0inhk