cms网站建设的优缺点,网站虚拟主机空间1g多吗,wordpress首页导航代码,北京建站公司JDK 8 升级 17
简介
从 JDK 8 升级到 JDK 17 的过程中#xff0c;有几个主要的变化#xff0c;特别是 Java Platform Module System (JPMS) 的引入#xff0c;以及一些包路径的调整。以下是与 JDK 17 相关的一些重要变化#xff1a; Java Platform Module System (JPMS) …JDK 8 升级 17
简介
从 JDK 8 升级到 JDK 17 的过程中有几个主要的变化特别是 Java Platform Module System (JPMS) 的引入以及一些包路径的调整。以下是与 JDK 17 相关的一些重要变化 Java Platform Module System (JPMS) 模块化JDK 9 引入了模块系统将标准 Java 库划分为多个模块。这影响了 JDK 17 中的包结构和类的组织方式。模块路径JDK 11 引入了 --module-path 和 --add-modules 选项允许用户指定模块路径和加载特定模块。 Java EE APIs 移除 JAX-RSjavax.ws.rs.* 包现在不在标准 Java SE 平台上。JAX-WSjavax.xml.ws.* 包现在不在标准 Java SE 平台上。JAX-Bjavax.xml.bind.* 包现在不在标准 Java SE 平台上。 其他变化 JavaFXJavaFX 已经从标准 Java SE 平台中移除现在作为一个独立的模块存在。 如果应用使用了 JavaFX确保已经添加了 JavaFX 模块到应用中 JSR 355JSR 355 定义了一些与 JavaFX 相关的包这些包也不再包含在标准 Java SE 平台上。 JDK 17 中的新特性 JEP 391: Foreign Function Memory API (Incubator)提供了与外部代码和内存交互的能力。JEP 403: Sealed Classes允许类声明为密封以限制继承。JEP 404: Pattern Matching for switch (Preview)引入了模式匹配支持到 switch 语句中。JEP 414: Vector API (Fourth Incubator)提供了一种利用向量硬件指令的途径。 javax.* 包移到 jakarta.* Jakarta EE 技术栈随着 Java EE 转变为 Jakarta EE许多 javax.* 包已经被迁移到 jakarta.*包下。这对于使用 Java Persistence API (JPA)、JSF、EJB 等技术的应用尤为重要。 javax.persistence.* - jakarta.persistence.*javax.faces.* - jakarta.faces.*javax.ejb.* - jakarta.ejb.*javax.servlet.* - jakarta.servlet.*javax.servlet.jsp.* - jakarta.servlet.jsp.*javax.websocket.* - jakarta.websocket.*javax.naming.* - jakarta.naming.*javax.sql.* - jakarta.sql.*javax.transaction.* - jakarta.transaction.* JDK 8 升级到 JDK 17 需确保代码中引用了正确的包名。应该使用 jakarta.* 而不是 javax.*。 maven pom 中更新 java 版本 建议在父项目添加全局变量 java.version然后在 maven-compiler-plugin 引用 propertiesjava.version17/java.versionproject.build.sourceEncodingUTF-8/project.build.sourceEncodingproject.reporting.outputEncodingUTF-8/project.reporting.outputEncoding
/propertiesbuildpluginsplugingroupIdorg.apache.maven.plugins/groupIdartifactIdmaven-compiler-plugin/artifactIdversion3.10.1/versionconfigurationsource${java.version}/sourcetarget${java.version}/targetencodingUTF-8/encoding/configuration/plugin/plugins
/buildspringboot 2.x 升级 3.x
spring-boot 与 cloud、alibaba-cloud 的版本对应 spring-cloud 与 spring-boot 的版本对应详见 spring-cloud 官方文档 spring-alibaba-cloud 与 spring-cloud、spring-boot 的版本对应详见 spring-alibaba-cloud 官方文档 redis 默认配置调整
在 Springboot 2.x 的版本中redis 的默认配置是 spring.redis.*升级成 Springboot 3.x 以后redis 的默认配置调整为了spring.data.redis.*。
若继续使用 Springboot2.x 的 redis 配置会导致获取不到 redis 的配置。 SpringBoot 3.x 整合 Querydsl
主要问题springboot 升级 3.0jpa 包路径从 javax 改成 jakarta在默认情况下无法生存 Q 类也没办法使用JPAQuery
解决方法 引入依赖。重点classifier 标签 dependencygroupIdcom.querydsl/groupIdartifactIdquerydsl-jpa/artifactIdclassifierjakarta/classifierversion5.0.0/version
/dependencydependencygroupIdcom.querydsl/groupIdartifactIdquerydsl-apt/artifactIdversion5.0.0/versionscopeprovided/scopeoptionaltrue/optionalclassifierjakarta/classifier
/dependency引入 maven plugin plugingroupIdcom.mysema.maven/groupIdartifactIdapt-maven-plugin/artifactIdversion1.1.3/versionexecutionsexecution!--goals--!-- goalprocess/goal--!--/goals--configurationoutputDirectorytarget/generated-sources/outputDirectoryprocessorcom.querydsl.apt.jpa.JPAAnnotationProcessor/processor/configuration/execution/executions
/plugin 注意每个项目配置可能会有差别在编译时可能会报错Attempt to recreate a file for type xxx导致此错误的情况也不太一致。可能的原因之一是因为配置了 goals所以此处注释掉 goals其他情况不一定能适用此方式。 其他注意事项 依赖循环引用 报错 如果升级前的 Spring Boot 版本早于 2.6.0且存在 spring ioc 对象的循环引用则需要添加允许循环引用的配置否则报错 spring:main:allow-circular-references: trueWebMvcConfigurerAdapter.class 找不到报错 Spring Boot 3 基于 Spring Framework 6而在 Spring Framework 5.3 中WebMvcConfigurerAdapter 类已经被弃用并在后续版本中移除。 解决方案 使用 WebMvcConfigurer 接口 WebMvcConfigurerAdapter 是一个抽象适配器类用于实现 WebMvcConfigurer 接口。 在 Spring Framework 6 中可以直接实现 WebMvcConfigurer 接口来定制 Web MVC 的行为。 创建自定义配置类 创建一个新的类实现 WebMvcConfigurer 接口并重写需要的方法。 Configuration
public class WebConfig implements WebMvcConfigurer {Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {// 自定义资源处理}Overridepublic void configurePathMatch(PathMatchConfigurer configurer) {// 自定义路径匹配}// 其他需要的方法
}Spring Boot 3.x 支持优雅退出添加以下配置开启 # 打开优雅退出
server:shutdown: graceful
# 多长时间后强制杀掉进程
spring:lifecycle:timeout-per-shutdown-phase: 30smaven 及 maven 插件的版本升级
maven 版本升级
为了确保 Maven 版本与 Java 17 兼容应该使用一个较新的 Maven 版本。Java 17 是一个长期支持 (LTS) 版本它是在 2021 年 9 月发布的。因此应该使用 Maven 3.6.0 或更高版本来确保良好的兼容性。
以下是几个推荐的 Maven 版本及其发布日期
Maven 3.6.0 - 发布于 2019 年 2 月 10 日Maven 3.6.3 - 发布于 2020 年 3 月 10 日Maven 3.8.1 - 发布于 2021 年 2 月 18 日Maven 3.8.5 - 发布于 2022 年 5 月 23 日
Maven 3.8.5 是一个较为推荐的版本因为它包含了对 Java 17 的良好支持以及一些重要的安全修复和改进。 升级 Maven 版本 查看当前 Maven 版本: 打开终端或命令提示符运行以下命令来查看已安装的 Maven 版本 mvn --version如果还没有安装 Maven或者安装的版本较旧可以按照下面的步骤安装或升级。 安装或升级 Maven: Windows 用户: 访问 Apache Maven 官方下载页面 下载最新的 Maven 版本。解压下载的文件到一个目录例如 C:\apache-maven-3.8.5。将 Maven 的 bin 目录添加到系统环境变量 PATH 中。设置 M2_HOME 环境变量值为 Maven 的安装目录。 Linux/macOS 用户: 使用包管理器安装 Maven例如对于 Ubuntu/Debian 使用 apt-get对于 macOS 使用 brew sudo apt update sudo apt install maven或者使用 Homebrew brew install maven或者从 Apache Maven 官网下载二进制分发包解压缩到 /usr/local 或其他位置并通过 mvn --version 确认安装成功。 设置 Java 17 作为默认 JDK: Windows 用户: 确保安装了 Java 17并将其路径添加到环境变量 JAVA_HOME 中。设置 JAVA_HOME 环境变量指向 Java 17 的安装目录。 Linux/macOS 用户: 安装 Java 17例如使用 sdkman 或者直接从 Oracle 或 Adoptium 下载。设置 JAVA_HOME 环境变量指向 Java 17 的安装目录。确保 JAVA_HOME 和 PATH 环境变量被正确设置。 验证 Maven 和 Java 版本: 再次运行 mvn --version 命令确保显示的 Java 版本为 17并且 Maven 版本为 3.8.5 或更高。 配置 Maven 以使用 Java 17: 在 pom.xml 文件中指定 Java 17 编译和源代码版本详见 maven-compiler-plugin 版本升级 maven-compiler-plugin 版本升级 为了确保 Maven 编译插件 (maven-compiler-plugin) 与 Java 17 兼容并支持 Spring Boot 3 的需求需要选择一个合适的 maven-compiler-plugin 版本。 截至2023年maven-compiler-plugin 的最新稳定版本是 3.10.1。该版本与 Java 17 兼容并且适用于 Spring Boot 3。 下面是 maven-compiler-plugin 的一个示例配置用于确保使用 Java 17 进行编译 buildpluginsplugingroupIdorg.apache.maven.plugins/groupIdartifactIdmaven-compiler-plugin/artifactIdversion3.10.1/versionconfigurationsource17/sourcetarget17/target/configuration/plugin/plugins
/build这里的关键配置点包括 source 和 target 都设置为 17以指示使用 Java 17 进行编译。version 设置为 3.10.1这是与 Java 17 兼容的一个版本。 **请注意需要根据实际的 Maven 和 Spring Boot 版本进行适当的调整。**如果需要使用特定版本的 maven-compiler-plugin请查阅官方文档或发布页面以确认版本的兼容性。