一点解决版本冲突的应急思路、怎样在所有jar包文件中搜索冲突的方法?
maven是一个很好的项目管理工具,你可以轻松的定义一个引用,从而达到使用别人写好的库的作用。且maven可以轻松地和jenkins配合,从而使打包部署变得更容易。
但是也因为这样,我们变得更傻瓜了,以致于有时候都忘了一些原始的基础的方法了,当然这不是本文的目的,本文的目的在于,如何解决一些maven带来的冲突问题。
问题1: jenkins 打包失败了,导致我无法安装代码到测试环境,怎么办?
答: 一般我们都会基于jenkins做一些二次开发,以适应公司内部的需求,或者优化一些修改化的东西。 但是由于jenkins本身还是比较复杂的,有时候难免我们搞不清楚其原理,从而导致一些无法打包的问题。 当然,我这边遇到的问题一般都是由于jenkins的缓存机制导致的问题,所以,在我本地可以打包的代码,放到jenkins上就死活打不了包,因为我依赖的一个jar包,由于被jenkins缓存了一个老版本的包,里面没有我新的东西从而导致打包失败,看起来短时间内无法解决这个缓存问题。
于是,我通过本地ide工具打好war包后,上传到服务器的tomcat目录,等待tomcat自动部署完成后就可以重新启动新代码了,从而绕过了jenkins失败的问题了。
针对jar包,则更为方便,直接本地生成jar包,然后替换服务器上的相应包,重启服务即可。
总之,这里的解决方案就是,当工具出了问题的时候,我们就不能再依赖工具了,回到原始状态解决问题。
问题2: 当我们运行了代码(war/jar)后,报某个方法未找到,即:java.lang.NoSuchMethodError:, 仔细查看代码,其实是有该方法的,如何排查?
答: 针对该问题,一般情况下都是由于引入了多个相同功能的jar包,且包路径完全一致,而在类加载器加载时,可能会加载到你不想要加载的类,从而导致没有该方法。
解决办法就是,删除不是自己的引用,从而达到使用自己意图的类。maven中即表现为排除某个依赖,如:
<dependency>
<groupId>com.xx.activity</groupId>
<artifactId>abc</artifactId>
<version>2.0.13-SNAPSHOT</version>
<classifier>dubbo</classifier>
<exclusions>
<exclusion>
<groupId>com.meidusa.venus</groupId>
<artifactId>venus-backend</artifactId>
</exclusion>
</exclusions>
</dependency>
但是,还有个问题,那就是如何才能找到是引用了哪个包,才导致的冲突呢?因为你从本地代码来看,没有一点异常。
我们可以直接搜索整个包的引用,并解开其中的代码,查看是冲突的类(冲突方法比较难找出来),当然是直接在服务器上进行查找了。
find . -name '*.jar' -exec jar -tvf {} \; | grep EE # 即找出所有的jar包,再解压出其文件列表,再搜索冲突的类名
如果有发现两个相同的结果,那么就是冲突了,解决该冲突即可。
当然,如果引入的jar文件不多,或者你有基本方向怀疑是哪个包冲突了,那么,直接将该包下载下来,用反编译工具(如jd-gui)编译出来,查看其内部情况,便一目了然。
问题3: 发现tomcat启动异常快,而且很多加载流程都没有,就直接启动了,实际上各个应有的服务都不存在,这怎么排查?
答: 这种问题比较没有头绪,解决起来也基本靠运气。 这里tomcat看起来正常启动了,但是实际上很多事情都没做,没加载。从另一个角度来说,就是加载中断了。最麻烦的是日志中一点信息都不会给出。一般可以先从代码的改动处开始排查,以一段一段的代码还原方式为主要排查手段。
其中有一很关键的问题就是,你引用了一个jdk版本比你自己的运行环境高的jar包,按照jvm的加载原理,其会先检查class文件的版本号,如果高于自己所能加载的版本,那么,它就直接拒绝加载了,而并不会检查该class文件是否引用了一些不认识的特性。如果jvm不加载类了,那么你后续流程就无法进行了。
如果确实是因为jar包版本导致的问题,那么,问题就好解决了。 1. 要么叫给你提供jar包的同学将其打包的jdk版本降到你需要的版本就可以了。 2. 升级自己的jvm运行环境,升级jdk, 当然这个风险可能会有,小心行事。
以上,就是一点点问题排查心得,聊以慰藉。也希望对有类似的问题的同学指明一个方向。
遇到问题的时候我们往往是这样,一个问题,可能几天下来也不一定能解决,但是到真正解决了的时候,发现其实很简单。然后,也许下一次,又继续!
一点解决版本冲突的应急思路、怎样在所有jar包文件中搜索冲突的方法?的更多相关文章
- 换个新的思路 代替解压jar包 例证:wechat4j 框架中的templateMsg类
很多朋友在写java的程序的时候都喜欢用第三方的jar包和框架,有可能遇到jar包中的内容已经跟不上官方开发者文档的更新,导致部分内容出错了,这个时候可能就要放弃这个jar的使用,但是这个jar中的其 ...
- 解决ecplise安装mybatipse插件时报找不到jar包的错
在安装mybatipse插件的时候一直报这个错,脑袋疼,在网上搜了半天也没有结果,最后摸索了半天解决了,这里先贴一张图 1.先找到eclipse的安装目录,然后把相应的jar包拷到plugins里去, ...
- Eclipse 查看第三方jar包文件源代码解决方法
1.打开第三方依赖包,源文件的快捷键:ctrl + mouseClick 2.由于我们下载的第三方jar 包,如Spring等相关的依赖包时,并没有附加下载相应的源文件,所以经常出现如图的这种问题. ...
- Eclipse 无法查看第三方jar包文件源代码解决方法
1.打开第三方依赖包,源文件的快捷键:ctrl + mouseClick 2.由于我们下载的第三方jar 包,如Spring等相关的依赖包时,并没有附加下载相应的源文件,所以经常出现如图的这种问题. ...
- 解决maven无法加载本地lib/下的jar包问题(程序包XXX不存在)
这次一个项目用到maven编译,我在本地开发的时候jar包都是放在WEB-INF/lib目录下,通过 BuildPath将jar包导入,然后用MyEclipse中的:maven package命令打成 ...
- 【转】解决maven无法加载本地lib/下的jar包问题(程序包XXX不存在)
原文链接:https://www.cnblogs.com/adeng/p/7096484.html 这次一个项目用到maven编译,我在本地开发的时候jar包都是放在WEB-INF/lib目录下,通过 ...
- Eclipse无法查看第三方jar包文件源代码解决方法
来源于:https://www.cnblogs.com/1995hxt/p/5252098.html 1.打开第三方依赖包,源文件的快捷键:ctrl + mouseClick 2.由于我们下载的第三方 ...
- jenkins 执行可执行jar包测试中,请求乱码解决办法
自动化脚本在eclipse中执行,没有问题.jenkins构建打包自动化脚本,在执行脚本时,遇到了脚本中发送的请求的参数为乱码,实现了如下一些解决办法: 1.设置操作系统环境JAVA_TOOL_OPT ...
- NetBeans IDE 7.4 Beta版本build JavaFX时生成的可执行jar包执行时找不到依赖的jar包
现象,执行时抛出java.lang.ClassNotFoundException异常: Executing E:\secondegg\secondegg-reversi\dist\run8022211 ...
随机推荐
- php常用面试题
1. 有一列数的规则如下 1.1.2.3.5.8.13.21.34... 求第30位数是多少.写出相关函数和算法名称 //$pxx = array(1,1);//for($i=2;$i<=29; ...
- Java设计模式之单例模式详解
在Java开发过程中,很多场景下都会碰到或要用到单例模式,在设计模式里也是经常作为指导学习的热门模式之一,相信每位开发同事都用到过.我们总是沿着前辈的足迹去做设定好的思路,往往没去探究为何这么做,所以 ...
- select联动遇到的问题
今天写了个select下拉联动,记录下过程中遇到的问题. dom部分 // 拿到选中项的索引 myselect.selectedIndex // 拿到选中项的text/value myselect.o ...
- 开源API测试工具 Hitchhiker v0.6更新 - 改进压力测试
Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起协作测试 ...
- 开发指南专题六:JEECG微云高速开发平台代码生成
开发指南专题六:JEECG微云高速开发平台代码生 1.1. 代码生成扫描路径配置 用代码生成器生成代码后.须要进行相关配置配置,扫描注入control.service.entity等; 具体操作过程例 ...
- myeclipse tomcat java.lang.OutOfMemoryError: PermGen space错误的解决方法
错误代码: java.lang.OutOfMemoryError: PermGen space 原因分析: myeclipse或tomcat的内容分配的不够用,启动失败 解决方法: 1.找到tomca ...
- EventBus在Android中的简单使用
EventBus是一个方便与Android中各组件通信的开源框架,开源地址;https://github.com/greenrobot/EventBus.EventBus功能非常强大 ,今天在做一个功 ...
- JAVA入门[16]-form表单,上传文件
一.如何传递参数 使用 @RequestParam 可以传递查询参数.例如:http://localhost:8092/category/detail?id=1 @RequestMapping(&qu ...
- 面向矩阵的numpy入门笔记
我先声明我学numpy的目的:在python中使用矩阵(我需要在机器学习中使用矩阵),所以我的目的很明确,矩阵: 矩阵在numpy中叫ndarray(The N-dimensional array), ...
- maven安装配置及使用maven创建一个web项目
今天开始学习使用maven,现在把学习过程中的资料整理在这边. 第一部分.maven安装和配置. http://jingyan.baidu.com/article/295430f136e8e00c7e ...