Spring Boot 3.2发布:大量Java 21的支持上线,改进可观测性

就在今天凌晨,Spring Boot 3.2正式发布了!该版本是在Java 21正式发布之后的重要支持版本,所以在该版本中包含大量对Java 21支持的优化。

下面,我们分别通过Spring官方发布的博文和Josh Long长达80+分钟的介绍视频,一起认识一下Spring Boot 3.2最新版本所带来的全新内容。

最新特性

通过官方博文的介绍,可以有个大致的最新特性了解,其中包括:

  • 支持虚拟线程
  • 对JVM Checkpoint Restore的初步支持(CRaC项目)
  • SSL 捆绑包重新加载
  • 大量可观察性改进
  • 支持 RestClient
  • 支持 JdbcClient
  • 支持 Jetty 12
  • Apache Pulsar 对 Spring 的支持
  • 对 Kafka 和 RabbitMQ 的 SSL 捆绑支持
  • 重新设计的嵌套 Jar 处理
  • Docker 镜像构建改进

此外,对于依赖的更新列表,因为比较长,这里DD就不列出来了,感兴趣的可以点击这里查看

视频介绍

下面,可以把关注点放到John Long的介绍视频里。一如既往的干货视频!通过在线编码的方式,直观的给大家展示新功能的魅力。

Tips:Josh Long的视频如果您不方便访问的话,DD这边给大家下载好了,同时也做了一份翻译字幕和中文配音视频。有需要观看的视频的小伙伴可以通过关注公众号:程序猿DD,发送关键词:springboot,获取下载链接。

下面是关于视频的总结,可以先大概看一下视频内容,感兴趣的话可以下载观看:

[00:16] Spring Boot 3.2带来了许多新功能,包括支持虚拟线程和Project Loom、改进的可观察性支持、可重载的SSL支持等。

  • Spring Boot 3.2带来了许多新功能,包括虚拟线程和Project Loom。
  • Java 21是Spring Boot 3.2的一个重要特性。
  • Java 21引入了一些新的语法变化,如封闭类型、模式匹配、智能开关表达式和记录。
  • Java 21被称为数据导向编程,旨在改进Java在大型单体应用中的表现。

[10:13] 使用字符串格式化和多行变量非常方便,还有一些新的特性,如模式匹配和解构操作符。

  • 字符串格式化和多行变量是方便的选项。
  • 新特性包括记录、密封类型、智能开关表达式和模式匹配。
  • 目前还没有解构操作符,但正在开发中。
  • 项目Loom虚拟线程是Java 21中的重要特性。

[20:27] 在这个片段中,演示了创建一个跳过重复项的集合,并使用线程来记录当前线程的名称和休眠100毫秒。

  • 创建了一个跳过重复项的集合。
  • 使用线程记录当前线程的名称。
  • 休眠100毫秒。
  • 演示了使用虚拟线程来执行Java代码。

[30:41] 在Spring Boot 3.2中,我们将使用Java 21、Maven和一些支持库来构建一个与SQL数据库通信的应用程序。

  • 使用了test containers API来启动Docker镜像。
  • 使用了spring boot starter jdbc依赖来连接PostgreSQL数据库。
  • 通过添加特定的配置来启动PostgreSQL容器。

[40:57] 使用Spring Boot 3.0中的声明式接口可以更简化代码,提供一个给定URL请求的猫事实。

  • 可以使用新的JDBC和REST客户端来调用端点。
  • 使用Project Loom和Drava 21,可以在Spring应用程序的不同层级中获得一致的虚拟线程集成。
  • 这种方法既具备了阻塞API的便利性,又不会丧失可用性。
  • 可以使用声明式接口来实现给定URL请求的猫事实。

[51:09] Spring框架中有一个称为SmartLifeCycle的接口,可以用来表示典型Spring生命周期的方法。

  • SmartLifeCycle是一个更智能的版本,用于让用户消费。
  • SmartLifeCycle的方法与检查点方法对应。
  • 可以使用SmartLifeCycle来管理应用程序的启动和停止。
  • 在这个例子中,通过实现SmartLifeCycle接口,可以实现应用程序的启动和停止功能。

[01:01:23] 通过一个文件来生成唯一的键值对,并且配置了一个自签名的SSL证书。

  • 在一个文件中写入数字,每次运行时递增并写入文件。
  • 生成的键值对是唯一的,用于展示随时间变化。
  • 配置了自签名的SSL证书,并通过指定端口号8443来使用。

[01:11:38] 在本地机器上,我们可以通过Zipkin来查看分布式追踪的图形

  • 使用Docker compose启动Zipkin实例
  • 在应用代码中增加采样概率
  • 通过aop支持在类路径上添加注解来显示跟踪ID和跨度ID
  • 通过Zipkin可以查看请求日志和服务之间的跳转

如果您学习过程中如遇困难?可以加入我们超高质量的Spring技术交流群,参与交流与讨论,更好的学习与进步!更多Spring Boot教程可以点击直达!,欢迎收藏与转发支持!

欢迎关注我的公众号:程序猿DD。第一时间了解前沿行业消息、分享深度技术干货、获取优质学习资源

热门相关:重生复仇:腹黑千金不好惹   重生复仇:腹黑千金不好惹   跟总裁假结婚的日子   厨道仙途   全天下都知道太子爱她