我把springboot项目从Java 8 升级 到了Java 17 的过程总结,愿为君提前踩坑!

项目从jdk8升级到jdk17,我不是为了追求java 17的新特性(准确来说也还没有去了解有什么新特性),也不是为了准确与时俱进,永远走在java行列的最前端,纯粹因为项目需要,因为我们都知道,只要项目能跑,你就不要动它!

目录

  • 背景
  • 目标
  • 环境安装
    • Java 17
      • 下载
        • 方式一
        • 方式二
      • 配置环境变量与java8共存
    • SpringBoot3.0.0
    • Maven 3.6.3+
    • Idea 2022.2.1+
      • 下载
      • 安装
  • 配置IDEA和项目 java17环境
    • IDEA中Maven设置
    • IDEA环境配置
      • Setting设置
      • Project Structure设置
  • 问题处理
    • 运行项目出现 无效的源发行版: 17
    • hibernate unknown
    • ERROR StatusLogger Unable to create Lookup for ctx
    • java.lang.TypeNotPresentException: Type javax.servlet.http.HttpServletRequest not present
    • swagger替换为openapi后,会有报错
    • flyway问题
    • 动态数据源问题
  • 最后

背景

Java 程序员应该都熟悉下面这句话: 版本任他发,我用 Java 8 。自从 2014 年 3 月 Java SE 8.0(1.8.0)发布,到现在已经是第九年,21 年 9 月 Java SE 17(LTS)也已经发布,但绝大部分 Java 开发人员依然使用 1.8 版本。懒惰是其中的一方面原因,生产环境稳定大于一切的压力之下,既然 Java8 已经表现很好没有什么问题,那么也就没有必要冒险去做版本升级了,毕竟“升级”在很多情况下都意味着工作量和风险。

不过在今年之后,这个情况发生了变化。由于厂商纷纷宣布即将停止 1.8 版本的更新维护:Oracle 于 2019 年 1 月停止商用用途中的更新,2020 年 12 月停止非商用版本更新;AdoptOpenJDK 于 2023 年 9 月或之前停止更新;Amazon Corretto 于 2023 年 6 月或之前停止更新。意味着 23 年 9 月之后,将不再有厂商继续更新 Java 8。

2014年发布的java SE 8和2017年发布的java EE 8,至今还是使用最广泛的java版本,大部分java开发者对于java 8之后的升级总是敬而远之,这跟java 9以后的破坏性升级和oracle的商用协议有关,但随着9月java 17的发布,我们有更多理由去升级和在新项目中使用更新的java了。


目标

本次操作是mac版本下的

  • Java 8 应用升级到 Java 17
  • SpringBoot 版本升级到 SpringBoot3.0.0
  • 推荐的 Java 17 开发环境包括:Maven 3.6.3+、Idea 2022.2.1+

环境安装

Java 17

下载

方式一

下载链接🔗:JDK开发工具包17.0.9下载

在这里插入图片描述
要选择对应的版本去下载,比如我mac,在左上角的苹果标志,直接点击,弹出菜单,点击“关于本机”,确认一下本机电脑的CPU是Intel还是ARM。

  1. 如果是Intel,点击“x64 DMG Installer”的右边网址
  2. 或者选择 macOS 下的 ARM64 DMG(适用于苹果芯片,如 M1、M2 等)

在这里插入图片描述
我的是M2,所以如上图

按照步骤直接默认选项安装即可。

方式二

在 mac 下,也可以使用 sdkman 来安装 jdk 和 maven:
(其实我一开始是使用的此方法,但是由于那会网络一直不稳定,最后还是使用的方法一)

命令行执行下面操作即可(sdk 相关命令可以使用 sdk help 查看)

curl -s "https://get.sdkman.io" | bash

sdk install java 22.3.r17-grl
sdk install maven 3.8.2

下载中截图
在这里插入图片描述

由于我网络不稳定,出现如下报错:

Installing script cli archive...
* Downloading...
curl: (28) Failed to connect to github.com port 443 after 75015 ms: Couldn't connect to server

'curl --fail --location --progress-bar "${SDKMAN_SERVICE}/broker/download/sdkman/install/${SDKMAN_VERSION}/${SDKMAN_PLATFORM}" > "$sdkman_zip_file"': command failed with exit code 28.

然后我就再次执行命令

curl -s "https://get.sdkman.io" | bash

结果提示已经存在,可以强制更新
在这里插入图片描述

算了,我还是卸载重新安装吧:

rm -rf "$HOME/.sdkman"

再次执行上面的安装命令
继续有报错出来

touch: /Users/myName/.bash_profile: Permission denied
'touch "$sdkman_bash_profile"': command failed with exit code 1.

可以看到上面报错是要修改.bash_profile文件,我们可以自己修改

vim ~/.bash_profile

.bash_profile文件最后一行加上下面内容

export SDKMAN_CANDIDATES_API=https://api.sdkman.io/2
[[ -s "$HOME/.sdkman/bin/sdkman-init.sh" ]] && source "$HOME/.sdkman/bin/sdkman-init.sh"

然后执行

source ~/.bash_profile

下载jdk17

sdk install java 22.3.r17-grl

下载中
在这里插入图片描述
我到这里又出现了下载超时的问题了,心里一万只🦙🦙🦙跑过啊,于是我果断去用了方式一


配置环境变量与java8共存

由于之前也是一直使用java8,所以下载安装完java17后,可以看下java版本是否有变
在这里插入图片描述

还是java8,因为我们的环境还是没有变,我的是.bash_profile文件
在这里插入图片描述

先看看下载的jdk17在不在默认下载的目录/Library/Java/JavaVirtualMachines

在这里插入图片描述
接下来就是更换环境变量,使用jdk17了,如下

vim ~/.bash_profile

增加如下内容

export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home
#export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Home
export PATH=$JAVA_HOME/bin:$PATH:.
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:.

在这里插入图片描述
然后执行保存,再查看版本

source ~/.bash_profile
java -version

可以发现已经是java17了
在这里插入图片描述

不同Java版本间的切换
若要将Java17切换到Java其他版本,只需要将.bash_profile文件中的JAVA_HOME改成Java其他版本的目录即可,修改的过程和之前配置JAVA_HOME环境变量类似。


SpringBoot3.0.0

查看springBoot版本

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.5.5</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

这里只要更换版本即可

<version>3.0.0</version>

然后reload maven,一定会有报错,这个我在下面也会有提到


Maven 3.6.3+

这里需要注意下载的版本是否是你的IDEA版本支持的Maven版本
Maven官网
在这里插入图片描述
点击 Download 拉到最底下,下载历史版本
在这里插入图片描述
下载解压更新系统变量就不说了


Idea 2022.2.1+

下载

因为社区版免费使用,所以下载社区版安装就好。下载的版本是Idea 2022.2.1+就可以,不做过多阐述。

下载地址:https://www.jetbrains.com/idea/download/#section=mac

安装

mac 下,ideaIC-2023.1.2-aarch64.dmg 直接双击安装,按照说明完成操作即可。接下来就是启动。

配置IDEA和项目 java17环境

IDEA中Maven设置

进入Idea File->settings…->Build,Execution,Deployment->Build Tools->Maven
在这里插入图片描述
还需要配置另两个地方:Runner和Importing内选择Java17
在这里插入图片描述
在这里插入图片描述

IDEA环境配置

Setting设置

在这里插入图片描述

Project Structure设置

File - Project Structure…

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⚠️如果编译项目出现 java: 无效的源发行版: 17,则需要设置:
在这里插入图片描述

全部配置完毕,就可以启动项目了,这就会遇到下面一堆的问题了,但是不要慌,我们一个个解决


问题处理

从这里开始,就是本篇的重点了,一个接一个地处理问题。

运行项目出现 无效的源发行版: 17

这个可能性是有两种

  1. 环境变量配置后没有成功保存

    • 打开shell,执行java -version命令,如果出现的是jdk17,则说明环境变量正确,反之再去修改环境变量
  2. idea在更换jdk后没有重启

如果没问题,查看项目目录 External Libraries 外部库中,使用的应该就是Java17,如下
在这里插入图片描述

hibernate unknown

maven中Dependencies引入的hibernate报错
在这里插入图片描述

其实就是版本兼容的问题
需要删除原来的依赖,然后升级版本:6.1.7.Final

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>6.1.7.Final</version>
        </dependency>

依赖默认情况下都在如下路径,后面的删除依赖也是同样的
在这里插入图片描述

ERROR StatusLogger Unable to create Lookup for ctx

启动报错
在这里插入图片描述

ERROR StatusLogger Unable to create Lookup for ctx
 java.lang.NoClassDefFoundError: org/apache/logging/log4j/util/ServiceLoaderUtil
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.util.ServiceLoaderUtil
	at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641)
	at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188)

这个可以看官方发行版本:log4j版本:2.22.0
其实也是版本兼容的问题,需要删除原来的依赖,然后升级版本:2.22.0


			<dependency>
				<groupId>org.apache.mvnging.log4j</groupId>
				<artifactId>log4j-core</artifactId>
				<version>2.22.0</version>
			</dependency>

			<dependency>
				<groupId>org.apache.logging.log4j</groupId>
				<artifactId>log4j-slf4j-impl</artifactId>
				<version>2.22.0</version>
			</dependency>

			<dependency>
				<groupId>org.apache.logging.log4j</groupId>
				<artifactId>log4j-jul</artifactId>
				<version>2.22.0</version>
			</dependency>

			<dependency>
				<groupId>org.apache.logging.log4j</groupId>
				<artifactId>log4j-api</artifactId>
				<version>2.22.0</version>
			</dependency>

java.lang.TypeNotPresentException: Type javax.servlet.http.HttpServletRequest not present

启动报错

java.lang.TypeNotPresentException: Type javax.servlet.http.HttpServletRequest not present
Caused by: java.lang.ClassNotFoundException: javax.servlet.http.HttpServletRequest

这个问题让我找了好半天的解决办法
参考链接:

  1. Springfox Type javax.servlet.http.HttpServletRequest not present
  2. Spring Boot3.0(六):整合swagger
  3. Type javax.servlet.http.HttpServletRequest not present #4061

原因是:SpringFox 和 Spring Boot 3 的组合将无法工作。这里就需要替换了

解决:
需要删除原来的依赖

  • 删除SpringFox的引用并且对于spring-boot和swagger-ui之间的集成
			<dependency>
				<groupId>io.springfox</groupId>
				<artifactId>springfox-boot-starter</artifactId>
				<version>${springfox.version}</version>
			</dependency>
  • 将库添加到项目依赖项列表中(无需额外配置):
<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
    <version>2.2.0</version>
</dependency>

swagger替换为openapi后,会有报错

这里替换为如下类即可
在这里插入图片描述
在这里插入图片描述
更多内容可以查看springfox迁移指南

flyway问题

org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration$FlywayConfiguration and org.flywaydb.core.api.configuration.FluentConfiguration
在这里插入图片描述

***************************APPLICATION FAILED TO START***************************Description:An attempt was made to call a method that does not exist. The attempt was made from the following location:

org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration$FlywayConfiguration.configureProperties(FlywayAutoConfiguration.java:234)The following method did not exist:    'org.flywaydb.core.api.configuration.FluentConfiguration org.flywaydb.core.api.configuration.FluentConfiguration.oracleSqlplus(boolean)'The calling method's class, org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration$FlywayConfiguration, was loaded from the following location:

Action:Correct the classpath of your application so that it contains compatible versions of the classes org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration$FlywayConfiguration and org.flywaydb.core.api.configuration.FluentConfiguration

解决
升级版本:

			<dependency>
				<groupId>org.flywaydb</groupId>
				<artifactId>flyway-core</artifactId>
				<version>7.14.0</version>
			</dependency>

并且:将属性设置为spring.flyway.enabled来禁用 Flyway 的自动配置

参考链接🔗:Spring-boot 3.0不支持flyway 7.15

动态数据源问题

***************************
APPLICATION FAILED TO START
***************************

Description:

Parameter 0 of constructor in com.axiomesh.bt.common.BTInitializer required a bean of type 'com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator' that could not be found.


Action:

Consider defining a bean of type 'com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator' in your configuration.

解决

  • 升版本
  • 改配置(dynamic-datasource-spring-boot-starter—》dynamic-datasource-spring-boot3-starter)
  • 删除依赖,重新下载
<dependency>
	<groupId>com.baomidou</groupId>
	<artifactId>dynamic-datasource-spring-boot3-starter</artifactId>
	<version>4.2.0</version>
</dependency>

在这里插入图片描述

然后再次启动项目,如果你还有别的问题,那就一一解决,大部分都是版本兼容问题、旧的依赖未清除问题,加油!


最后

  • 好看的灵魂千篇一律,有趣的鲲志一百六七!
  • 如果觉得文章还不错的话,可以点赞+收藏+关注 支持一下,鲲志的主页 还有很多有趣的文章,欢迎小伙伴们前去点评
  • 如果有什么需要改进的地方还请大佬指出❌

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/224224.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【华为数据之道学习笔记】3-1 基于数据特性的分类管理框架

华为根据数据特性及治理方法的不同对数据进行了分类定义&#xff1a;内部数据和外部数据、结构化数据和非结构化数据、元数据。其中&#xff0c;结构化数据又进一步划分为基础数据、主数据、事务数据、报告数据、观测数据和规则数据。 对上述数据分类的定义及特征描述。 分类维…

HarmonyOS学习--TypeScript语言学习(四)

注意&#xff1a;这只是我学习的笔记&#xff01;&#xff01;&#xff01; 注意&#xff1a;这只是我学习的笔记&#xff01;&#xff01;&#xff01; 注意&#xff1a;这只是我学习的笔记&#xff01;&#xff01;&#xff01; 本章目录如下&#xff1a; 一、对象 二、接口…

配置CentOS服务器以支持PHP

CentOS是一款优秀的开源服务器操作系统&#xff0c;为各种网络服务提供了强大的支持。为了使CentOS服务器能够支持PHP&#xff0c;我们需要进行一些必要的配置。下面将介绍配置CentOS服务器以支持PHP的关键步骤。 安装PHP 首先&#xff0c;需要安装PHP解释器。在CentOS上&…

[UIM]论文解读:subword Regularization: Multiple Subword Candidates

文章目录 一、完整代码二、论文解读2.1 介绍2.2 NMT2.3 Unigram language model2.4 subword 抽样2.5 效果 三、整体总结 论文&#xff1a;Subword Regularization: Improving Neural Network Translation Models with Multiple Subword Candidates 作者&#xff1a;Taku Kudo 时…

【分布式微服务专题】从单体到分布式(一、SpringCloud项目初步升级)

目录 前言阅读对象阅读导航前置知识笔记正文一、单体服务介绍二、服务拆分三、分布式微服务升级前的思考3.1 关于SpringBoot/SpringCloud的思考【有点门槛】 四、SpringCloud升级整合4.1 新建父子项目 学习总结感谢 前言 从本节课开始&#xff0c;我将自己手写一个基于SpringC…

智能优化算法应用:基于非洲秃鹫算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于非洲秃鹫算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于非洲秃鹫算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.非洲秃鹫算法4.实验参数设定5.算法结果6.参考…

docker安装及配置mysql

docker 安装mysql 下载镜像文件 下载mysql5.7版本 sudo docker pull mysql:5.7检查是否下载成功 sudo docker images2.创建实例并启动 切换到root下避免每次使用sudo 密码&#xff1a;vagrant docker run -p 3306:3306 --name mysql \ -v /mydata/mysql/log:/var/log/my…

PACS源码,医学影像传输系统源码,全院级应用,支持放射、超声、内窥镜、病理等影像科室,且具备多种图像处理及三维重建功能

​三维智能PACS系统源码&#xff0c;医学影像采集传输系统源码 PACS系统以大型关系型数据库作为数据和图像的存储管理工具&#xff0c;以医疗影像的采集、传输、存储和诊断为核心&#xff0c;集影像采集传输与存储管理、影像诊断查询与报告管理、综合信息管理等综合应用于一体的…

AI助力智慧农业,基于YOLOv4开发构建不同参数量级农田场景下庄稼作物、杂草智能检测识别系统

智慧农业随着数字化信息化浪潮的演变有了新的定义&#xff0c;在前面的系列博文中&#xff0c;我们从一些现实世界里面的所见所想所感进行了很多对应的实践&#xff0c;感兴趣的话可以自行移步阅读即可&#xff1a; 《自建数据集&#xff0c;基于YOLOv7开发构建农田场景下杂草…

【开源】基于JAVA的APK检测管理系统

项目编号&#xff1a; S 038 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S038&#xff0c;文末获取源码。} 项目编号&#xff1a;S038&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 开放平台模块2.3 软…

翻译: 大语言模型LLMs能做什么和不能做什么 保存笔记What LLMs can and cannot do

生成式 AI 是一项惊人的技术&#xff0c;但它并非万能。在这个视频中&#xff0c;我们将仔细看看大型语言模型&#xff08;LLM&#xff09;能做什么&#xff0c;不能做什么。我们将从我发现的一个有用的心理模型开始&#xff0c;了解它能做什么&#xff0c;然后一起看看 LLM 的…

ThreadX开源助力Microsoft扩大应用范围:对比亚马逊AWS的策略差异

全球超过120亿台设备正在运行ThreadX&#xff0c;这是一款专为资源受限环境设计的实时操作系统。该操作系统在微控制器和小型处理器上表现出色&#xff0c;以极高的可靠性和精确的时间控制处理任务而闻名。 ThreadX曾是英特尔芯片管理引擎的引擎&#xff0c;并且是控制Raspber…

unity 2d 入门 飞翔小鸟 飞翔脚本(五)

新建c#脚本 using System.Collections; using System.Collections.Generic; using UnityEngine;public class Fly : MonoBehaviour {//获取小鸟&#xff08;刚体&#xff09;private Rigidbody2D bird;//速度public float speed;// Start is called before the first frame up…

挑选数据可视化工具:图表类型、交互功能与数据安全

作为一名数据分析师&#xff0c;我经常需要使用各种数据可视化工具来将数据以直观、清晰的方式呈现出来&#xff0c;以便更好地理解和分析。在市面上的众多可视化工具中&#xff0c;我根据实际需求和项目特点进行选择。本文将从以下几个角度对市面上的数据可视化工具进行对比&a…

Ros智行mini,opencv,Gmapping建图,自主导航auto_slam,人脸识别,语音控制

功能 一、Gmapping建图 二、自主导航 起始点 、终点 三、人脸识别 四、语音控制 完成任务: 机器人先建图 建完图后给出目标点&#xff0c;机器人就可以完成调用自主导航走到目标点&#xff0c;期间会调用激光雷达扫描局部环境来进行自主避障&#xff0c;到达终点后进行语音…

指针(进阶)

指针进阶&#xff1a; 通过指针基础我们已经了解了指针&#xff0c;这篇文章我们会举大量的例子&#xff0c;使我们对指针透彻理解&#xff0c;我们下来看一段代码&#xff1a; int main() {char a[] "ab";char* pc a;printf("%c\n", *pc);printf("…

线上项目修改最后一招 修改jar中的文件并重新打包成jar

解压jar包 在要操作的jar文件上边cmd打开命令提示符窗口&#xff08;windows系统&#xff09;&#xff0c; 在cmd命令下执行 jar -xvf xxx.jar 解压jar包&#xff08;其中xxx.jar换成你的jar包名&#xff09; jar -xvf admin-1.0.0.jar 替换或者更改操作 如果要替换jar压缩…

qt 5.15.2 主窗体菜单工具栏树控件功能

qt 5.15.2 主窗体菜单工具栏树控件功能 显示主窗体效果&#xff1a; mainwindow.h文件内容&#xff1a; #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QFileDialog> #include <QString> #include <QMessageBox>#inc…

浅谈web性能测试

什么是性能测试&#xff1f; web性能应该注意些什么&#xff1f; 性能测试&#xff0c;简而言之就是模仿用户对一个系统进行大批量的操作&#xff0c;得出系统各项性能指标和性能瓶颈&#xff0c;并从中发现存在的问题&#xff0c;通过多方协助调优的过程。而web端的性能测试…

ChatGPT能帮助--掌握各种AI绘图工具,随意生成各类型性图像

2023年随着OpenAI开发者大会的召开&#xff0c;最重磅更新当属GPTs&#xff0c;多模态API&#xff0c;未来自定义专属的GPT。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义&#xff0c;不亚于互联网和个人电脑的问世。360创始人周鸿祎认为未来各行各业如果不能搭上这班车…