Java类加载异常:NoClassDefFoundError与ClassNotFoundException
qiyuwang 2024-11-05 12:20 26 浏览 0 评论
一、NoClassDefFoundError:运行时加载不到类
在运行时,需要使用该类时,如调用该类的静态static方法或者创建该类的对象,无法从类路径加载该类而发生错误。无法加载可能类路径和mavne仓库确实是没有这个类,或者该类对当前的类加载器不可见,如tomcat容器中的不同应用使用不同类加载器。
出现场景:
- 常出现在:当通过手动安装某个第三方jar包,假如为A包,而A包又引用了另外一个jar包,假如为B包。在应用代码中需要直接引用A包的类,由于手动安装了A包到类路径中,故在编译时,应用代码可以顺利通过编译,即mvn clean compile通过。在运行时,A包的类在内部需要使用B包的类(注意应用代码没有显式使用B包的类,这个是导致与ClassNotFoundException不同的原因),由于是使用手动安装A包,而没有安装B包,当前类路径没有B包的类,故运行时会显示NoClassDefFoundError。如果不是通过手动安装jar包,而是通过maven,则会自动安装B包解决依赖,一般不存在这个问题。
- 这种错误经常出现在本地和测试可以编译通过并且运行成功,而发布到线上编译也是成功,但是运行时则报NoClassDefFoundError的错误。这是因为在本地和测试的.m2的maven仓库存在B包,如由于其他项目之前用到已经安装到了.m2的本地maven仓库中。而当部署到线上时,由于线上环境,即线上机器的.m2的maven仓库没有B包,故无法加载到B包的类而报错。
- 在springboot项目中,通常在线上环境,会通过编写一个shell脚本来编译启动项目,shell脚本的一般流程为:编译项目,编程成功则停止之前的进程,启动新的进程。而针对这个错误,由于是可以成功通过编译的,如使用mvn clean compile时,会显示Buid Successfully。但是在运行时启动项目,如启动springboot项目,调用SpringBootApplication的main方法时,发生错误。当出现该错误时,则无法启动新的进程,而由于之前进程又被杀死了,故应用此时是没有启动的,所以要额外注意,检查日志打印是否存在异常,并且执行回滚操作,否则线上服务会不可用。
二、ClassNotFoundException:编译时加载不到类
在编译时,由于在类路径和maven仓库.m2,加载不到对应的类而无法编译通过。即通过mvn clean compile编译项目时,会显示BUILD FAILURE。如果在线上通过刚刚描述的shell脚本的那个流程来启动项目,即编译失败则不停止之前的进程,这种情况下,原来进程还在运行,问题不大。所以ClassNotFoundException比NoClassDefFoundError更加容易解决和发现,对线上影响较小,因为还没编译通过。而NoClassDefFoundError是在运行时需要使用某个类时,无法加载才会报错,所以需要通过检查日志来发现。
出现场景:
- 本地和测试刚开始使用maven方法,即在pom.xml文件直接添加dependency依赖,来引用某个第三方jar包,记为A包,由于maven自动解决了依赖,在本地和测试机的.m2的maven仓库安装了A包依赖的其他jar包,记为B包(在应用代码中需要显式使用B包的类,即在应用代码中import了这个类),所以可以顺利编译通过。而后来由于A包由于某些特殊改动,发了一个新的jar包,由于是定制化的改动,故没有发布到maven仓库,故需要应用代码将A包放到项目的libs目录并手动安装。这时在本地和测试手动安装了A包,而没有手动安装该jar包依赖的B包,由于之前通过maven的方式自动到了机器的maven仓库中了,故可以进行正常编译启动。
- 而当上传到线上机器时,只手动安装了A包,而由于线上机器的maven仓库.m2中,没有安装过该jar包依赖的B包,而在应用代码中又显式使用了B包的类,即在应用代码中import了这个类,故在线上会编译失败。如果应用代码没有显示使用B包的类,而只是在A包内部使用,则会报NoClassDefFoundError。
三、完整例子
公司A提供了一个功能包func.jar,这个func.jar依赖公司A自己的一个commom.jar包,而common.jar依赖了google的gson包。具体的maven依赖关系可以在项目主目录下,通过mvn dependency:tree命令来查看。
ClassNotFoundException
只手动安装了func.jar,应用代码显示import了common.jar包的类,则代码会直接报错,如idea显示红色错误。通过mvn clean compile编译,则编译失败BUILD FAILURE。
NoClassDefFoundError
手动安装了func.jar和common.jar,没有安装或者通过maven方式引入google的gson包,由于应用代码没有显式使用gson的类,而是common.jar内部会使用,故应用代码不会报错,编译通过。在运行时,调用到common.jar包的类,该类又使用了gson包的类,由于类路径和maven仓库不存在gson包,故无法加载到该类,报NoClassDefFoundError。
相关推荐
- windows开启telnet服务,检测远程服务端口是否可以连通
-
本文介绍windwos开启telnet服务,telnet服务一般可以用于检测远程主机的某个端口服务是否可以连通,在日常的工作中,我们经常会遇到在本地的windows检测远程服务端口是否可以连通。win...
- 仅在Web登录新华三交换机条件下启用设备Telnet登录方式
-
概述Web登录新华三交换机可以在“网络-服务”页面中启用设备Telnet服务或SSH服务,也可以在“设备-管理员”设置管理员用户的可用服务,然而,在设备Web页面中,无法设置lineVTY用户线【l...
- 思科交换机,路由器如何关闭telnet 开启ssh服务
-
SSH为建立在应用层基础上的安全协议。SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用SSH协议可以有效防止远程管理过程中的信息泄露问题。今天我们就来说说思科交换机,路...
- 智能化弱电行业常用的DOS命令,掌握了你也能成为...
-
前言在做智能化弱电项目时,前端摄像头设备安装结束后,我们会对网络摄像头进行调试,调试过程中会遇到前端摄像头没有图像或者图像出来了画面卡顿的现象。我们会采用ping命令来测试网络的连通性和网络承载能力。...
- 「干货」eNSP模拟器之配置Telnet登录
-
配置说明:配置Telnet,使R2(模拟PC)通过SW1登录到R1进行管理和配置。操作步骤:system-view##进入系统视图[Huawei]sysnameR1##改名为R1[R1]int...
- win11开启telnet服务怎么操作 win11打开telent指令是什么
-
telnet服务是我们在进行远程连接的时候,必须要打开的一项功能。但是有不少用户们不清楚在windows11系统中怎么开启telnet服务。今天小编就使用详细的图文教程,来给大家说明一下打开telen...
- 华三(H3C)交换机Telnet的远程登陆
-
一,配置交换机管理IP[SW1]vlan20//创建管理vlan[SW1]interfacevlan20//进入vlan接口[SW1-Vlanif20]ipaddress192.168....
- win10 telnet命令怎么查看端口是否打开
-
可能大家也会遇到这个问题,win10telnet命令查看端口是否打开的步骤是什么?具体方法如下:1、键盘输入快捷键WIN+R,打开运行窗口。2、输入cmd,点击确定按钮。3、弹出cmd命令行窗...
- Windows 7如何打开Telnet功能(win7系统打开telnet)
-
Windows7默认安装后是没有开启telnet客户端功能的,例如,我们在开始菜单中输入cmd,然后使用telnet命令,会弹出下图提示:‘telnet’不是内部或外部命令,也不是可运行程序或批处理文...
- 为锐捷路由器交换机开启web和telnet,实现轻松管理
-
笔者上一篇文章写了关于锐捷二层交换机配置教程,那么接下来讲一下锐捷的路由交换设备配置web、telnet技巧。同样,今天的教程也是基于命令行,比较简单,适合新手小白进行学习。准备工作配置前准备:con...
- 一文学会telnet命令的用途和使用方法
-
Telnet是一个古老的远程登录协议,可以让本地计算机获得远程计算机的工作能力。它采用了TCP的可靠连接方式,可以连接任何网络互通的远程计算机。不过由于它采用了明文传输方式,存在安全风险,目前已经很少...
- Telnet命令是什么?如何使用?(telnet命令在哪里开启)
-
telnet命令是一个常用的远程登陆工具,使用它,我们可以快捷地登陆远程服务器进行操作。那么如何使用telnet命令呢?首先,我们需要打开telnet功能,任何电脑默认是关闭此功能的,开启方式如下:打...
- win11系统如何开启telnet服务(拷贝版本)
-
我们要知道,Telnet协议是Internet远程登陆服务的标准协议,可以使用户在本地计算机上完成远程主机的工作,不过对于一些刚接触win11中文版系统的用户来说,可能还不知道telnet服务在哪...
- 如何开启telnet客户端(如何开启telnet服务)
-
Telnet协议是TCP/IP协议家族中的一员,是Internet远程登陆服务的标准协议和主要方式,Telnet是常用的远程控制Web服务器的方法。工作中经常用到telnet客户端,但在windows...
- Telnet 是什么,如何启用它?(telnet有什么用)
-
对于Internet等TCP/IP网络,Telnet是一个终端仿真程序。Telnet软件在您的系统上运行并将您的个人计算机链接到网络服务器。它将所有数据转换为纯文本这一事实被认为是易受...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- navicat无法连接mysql服务器 (65)
- 下横线怎么打 (71)
- flash插件怎么安装 (60)
- lol体验服怎么进 (66)
- ae插件怎么安装 (62)
- yum卸载 (75)
- .key文件 (63)
- cad一打开就致命错误是怎么回事 (61)
- rpm文件怎么安装 (66)
- linux取消挂载 (81)
- ie代理配置错误 (61)
- ajax error (67)
- centos7 重启网络 (67)
- centos6下载 (58)
- mysql 外网访问权限 (69)
- centos查看内核版本 (61)
- ps错误16 (66)
- nodejs读取json文件 (64)
- centos7 1810 (59)
- 加载com加载项时运行错误 (67)
- php打乱数组顺序 (68)
- cad安装失败怎么解决 (58)
- 因文件头错误而不能打开怎么解决 (68)
- js判断字符串为空 (62)
- centos查看端口 (64)