分享解决jar包冲突问题的方法:(看了这个你就能解决所有包冲突问题!)
1. 问题描述:(maven+eclipse环境)
1.1. 昨晚发布这个新功能(接入notify消息中间件)预发失败!报:nested exception is java.lang.NoSuchMethodError: org.springframework.util.ResourceUtils.toURI(Ljava/lang/String;)Ljava/net/URI;
1.2. 但是我本地环境启动jetty没有报这个问题。
2. 解决方法:
2.1. 到项目根目录执行depth.bat(mvn dependency:tree > dep.txt)意思是把mvn各个包的依赖关系整理出来,发现新接入notify包下面有个spring2.5.1的包,而spring的包在dep.txt已经存在而且是3.1.1版本。
2.2. 那这样就很清楚了,预发的时候启动应用服务器可能默认使用了2.5.1包,而这个包的ResourceUtils类跟其他jar包不合,所以需要去掉这个低版本的spring包的依赖。这样可以在在pom文件里面的加上<exclusions><exclusion><groupId>org.springframework</groupId><artifactId>spring</artifactId></exclusion></exclusions>
2.3. 理应问题就这样解决了,但是我本地再测试的时候,发现应用能正常启动,但是测试发送notify消息又出现了包冲突,尼玛~ 报错:java.lang.NoSuchMethodError: com.taobao.eagleeye.EagleEye.rpcClientSend()V。
2.4. 再次检查dep.txt文件发现eagleEye依赖的是1.0.0版本,而且在tddl的3.0.1.6版本下面。推断是这个eagleEyejar版本低了,但又不能把tddl的3.0.1.6版本随意提高
2.5. 检查我pom文件里面notify依赖配置是<dependency><groupId>com.taobao.hsf</groupId><artifactId>hsf.notify.spring</artifactId><version>1.4.9.6</version></dependency>
2.6. 推测是hsf管理的notify需要更好的eagleEye版本,而dep.txt文件显示它自己又没有依赖引用更高的eagleEye版本,导致系统默认只能使用了tddl的3.0.1.6版本下面eagleEye1.0.低版本
2.7. notify官网还有另外一种依赖配置就是:<groupId>com.taobao.notify</groupId> <artifactId>notify-tr-client</artifactId> <version>1.8.15</version>
2.8. 试下这个,然后加上去掉spring的<exclusions>块,两个问题都就这样解决了!
2.9. 为什么发布预发之前我本地可以一切正常呢?还原到以前的pom文件查了也有spring2.5.1和spring3.1.1的两个包同时存在。我这里只能推测eclipse里面jvm默认使用了高版本,2.5.1版本的spring被默认忽略了。这点望大牛补充指点。
最后的pom.xml配置:
<dependency>
<groupId>com.taobao.notify</groupId>
<artifactId>notify-tr-client</artifactId>
<version>1.8.15</version>
<exclusions>
<!-- 因为hsf.notify.spring 1.4.9.6版本里面带有2.5.1spring,而这个项目上面都是引用3.1.1版本的spring,所以需要这里特殊去掉spring引用 -->
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
</exclusion>
</exclusions>
</dependency>
3. 以后注意经验:
3.1 以后往pom文件里面加依赖,都需要运行mvn dependency:tree查下各个包是否有冲突的问题,不能出现有两个相同包而版本不一致的情况
3.2 目前我们系统由于没有使用hsf来统一管理集团内部这些二方库,所以很容易出现这个问题。以后新项目可以考虑使用hsf容器来管理这些,升级应该都更方便
3.3 既然我们项目没有使用hsg统一管理包的依赖,则以后接入新二方库使用单独引用的方式,这样可以尽量减少eagleEye低版本类似问题!
3.4 本地运行OK,不一定代表预发和线上就运行OK!预发环境的建立对于公司,尤其是重要项目是非常必要的!
转载地址:https://blog.csdn.net/skeven1688/article/details/17615613
分享解决jar包冲突问题的方法:(看了这个你就能解决所有包冲突问题!)相关推荐
- 计算机中丢失msvcp40.dll,计算机中丢失MSVCR120.dll怎么办?解决电脑丢失MSVCP120.DLL的方法...
最近有很多用户反映在使用Win10系统看视频或者玩游戏的时候,系统系统提示无法启动此程序,这是什么原因导致的呢?这是因为计算机中丢失MSVCR120.dll,尝试重新安装该程序以解决此问题,这里小编为 ...
- unity怎么设置游戏页面_王者荣耀李小龙粤语语音包怎么得?李小龙粤语语音包获取与设置方法介绍[多图] - 游戏攻略...
王者荣耀游戏中,李小龙有他的专属粤语语音,想要使用粤语语音先要获取语音包后才能设置,以下是王者荣耀李小龙皮肤粤语语音包获取与设置方法介绍. 王者荣耀李小龙皮肤粤语语音包获取与设置方法介绍: 王者荣耀裴 ...
- linux top 源码,在Linux系统中下载源码包安装Topgrade的方法,附Topgrade选项说明
本文介绍在Linux操作系统中下载源码包安装Topgrade的方法,即下载topgrade-v2.3.0-x86_64-unknown-linux-gnu.tar.gz包并进行安装,经测试,在Ubun ...
- 在IDEA中解决jar包冲突的神操作-必看,秒杀市面方法
在开发过程中,经常会遇到导入jar包后jar包冲突的情况,大家也都知道,解决jar包冲突通常都比较麻烦,要找到多余的依赖,把低版本的依赖去掉.而大家通常能搜到IDEA解决jar包冲突的方法,应该是这样 ...
- Maven:解决jar包冲突和企业开发常用编写
QUESTION:Maven:解决jar包冲突和企业开发常用编写 目录 QUESTION:Maven:解决jar包冲突和企业开发常用编写 ANSWER: 一:Maven的作用 二:解决jar包冲突: ...
- 在IDEA中解决jar包冲突的神操作-必看
在开发过程中,经常会遇到导入jar包后jar包冲突的情况,大家也都知道,解决jar包冲突通常都比较麻烦,要找到多余的依赖,把低版本的依赖去掉.而大家通常能搜到IDEA解决jar包冲突的方法,应该是这样 ...
- idea解决jar包冲突的实用技巧
背景:在项目开发过程中,我们经常会使用到maven来管理jar包并作为项目打包构建工具,但是经常会遇到jar包冲突的问题 下面就分享一下解决jar包冲突的几个实用技巧 1.比如说:经常遇到NoClas ...
- 详述使用 IntelliJ IDEA 解决 jar 包冲突的问题
在实际的 Maven 项目开发中,由于项目引入的依赖过多,遇到 jar 冲突算是一个很常见的问题了.在本文中,我们就一起来看看,如何使用 IntelliJ IDEA 解决 jar 包冲突的问题!简单粗 ...
- was服务器里面jar包_如何在was中解决jar包冲突
如何在 was 中解决 jar 包冲突 大型的基于 WebSphere 的项目开发中,同一个 WebSphere Application Server (以下 简称 WAS ) 上会部署多个应用程序, ...
- Idea导出jar包运行报错:找不到主清单属性解决方法
Idea导出jar包运行报错:找不到主清单属性解决方法 参考文章: (1)Idea导出jar包运行报错:找不到主清单属性解决方法 (2)https://www.cnblogs.com/stars-on ...
最新文章
- 在Ubuntu 16.04.6 LTS上升级Go到最新版1.12.5实录
- mysql 插入汉字 异常 Incorrect string value: '\xE8\xA7\x84\xE5\x88\x99' for column 'name'
- python下什么-python要下什么
- Hyperopt 入门指南
- codevs 2865 天平系统1
- pycharm python 如何快速给代码块添加try/catch try/finally包裹?【ctrl+alt+T】
- 华为魔术手机拆机图解_华为P9进水不显示维修案例
- 4. Spring 如何通过 XML 文件配置Bean,以及如何获取Bean
- 【读书笔记】并发编程需要注意的几个典型问题
- bootstrapt学习指南_TensorFlow 2.0深度强化学习指南
- 关于Lodop打印控件
- mysql三大范式 答案_数据库逻辑设计之三大范式通俗理解,一看就懂,书上说的太晦涩...
- Go官方库RPC开发指南
- 【Javascript第二重境界】序
- echarts源码打包_Echarts源码阅读指南
- python实现excel的覆盖写入和追加
- centos7全盘备份到本地_centos7磁盘备份和还原
- could not resolve xxx.jar
- 怎么更改网络选项为家庭计算机,教你无法设定这是一台家庭计算机怎么操作
- vscode跳转返回快捷键
热门文章
- 微信公众号自定义菜单修改
- ORA-01790 expression must have same datatype as corresponding expression 问题解决
- Java设计模式:模板模式
- parameter与argument,property与attribute,这些翻译意思相近的词的区别
- 解决pycharm下载第三方库速度慢的问题
- cannot allocate memory in static TLS block问题记录
- puppet master/agent
- vbscript错误代码及对应解释大全
- 面圆机的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告
- ceph 代码分析 读_Ceph代码分析-OSD篇