问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl

文章目录

  • 问题场景
  • 问题环境
  • 问题原因
  • 解决方案
  • 结果
  • 总结
  • 随缘求赞

问题场景

有一个老项目,其中的tomcat有引入听云的插件。之后,因为项目不需要了,所以需要移除相关的插件。之前是直接在启动命令里面加上javaagent参数。现在移除了这个参数,但是启动了,提示报错,报错提示如下:

java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1720)
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1571)
        at org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:126)
        at org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:63)
        at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
        at java.lang.Class.forName0(Native Method)
        at java.lang.Class.forName(Class.java:169)
        at org.apache.jsp.admin.commonModule.fastdfs.index_jsp._jspService(index_jsp.java:180)
        at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:439)
        at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395)
        at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)

问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl_第1张图片

问题环境

软件 版本
tomcat 7.0
JDK 1.6

问题原因

如果了解tomcat的目录结构的话,遇到这个问题的时候,应该知道是为什么。这是tomcat的内部机制导致的。对于JSP文件,tomcat在调用JSP页面的时候,在第一次调用的时候,会在本地的工作目录的work/Catalina/生成对应的域名的文件夹,里面会存放对应的JSP生成的java文件,并进行编译,形成对应的class文件。如下图:
在这里插入图片描述
所以,如果是新页面,第一次调用的时候,会比较慢。等编译成功之后,调用起来就比较快了。之后,如果JSP页面有变动的时候,tomcat检测到就会进行更新。
问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl_第2张图片
所以,有经验的运维及开发,就会在更新代码的时候,顺便删除掉 work目录,避免出现问题。
问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl_第3张图片
那么,听云这个插件启动的时候,会在对应的页面加入对应的代码。而这部分代码已经被生成在work目录下面了。如果我们只是移除插件,而没有变动代码,那么原来已经包含插件的代码就会出现问题。

解决方案

问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl_第4张图片
既然知道了原因了,那我们在脚本移除听云的配置的时候,也得将tomcatwork目录给删除掉。

结果

tomcatwork目录给删除掉,重新启动无报错。
问题解决:启动tomcat,日志输出:java.lang.ClassNotFoundException: com.tingyun.api.agent.TingYunApiImpl_第5张图片

总结

了解tomcat的目录结构,遇到一些问题,就可以很轻易的解决掉。

随缘求赞

如果我的文章对大家产生了帮忙,可以在文章底部点个赞或者收藏;
如果有好的讨论,可以留言;
如果想继续查看我以后的文章,可以点击关注
可以扫描以下二维码,关注我的公众号:枫夜之求索阁,查看我最新的分享!
在这里插入图片描述
拜拜

你可能感兴趣的:(问题修复记录,中间件学习系列)