使用alibaba微服务体系搭建的项目,模块管理使用的maven,给项目引入swagger做接口文档,启动时报错,报错信息如下:
2.问题解决
升级guava版本为20.0以上。
3.问题排查思路
首先,查看错误日志,错误日志中英文的大体翻译为,“尝试调用了一个不存在方法,发生的位置在 DefaultModelDependencyProvider类中,下面这个方法不存在,可能方法存在....,guava-19.0.jar包中"
然后从错误日志中我们就可以分析出,由于guava-19.0这个jar引起的,并且报出的错误是某个方法不存在,那么我们就可以考虑到是这个jar的版本太低了,但是和swagger有什么关系那?那这个时候我们可以想到swagger有没有使用guava,打开编译器,查看swagger的包依赖关系:
使用idea的可以这样 *** 作,右侧---》maven--->选中需要分析依赖的项目---》maven最上方有个show depenceies--->然后打开下面这张图--》左上角有个有 show conflicts--》红线就是有冲突的依赖--》放大就会发现如第二张图 swagger也依赖了guava,并且要求20.0的版本。
4.根本原因
maven的父子模块包依赖机制导致,父子项目依赖关系如下:
我们的项目就是在 父项目中引入的swagger,里面的swagger自己引入了20.0以上版本的guava使用,但是我们在子项目中又添加了如下依赖:
导致父项目的guava版本被覆盖成了19.0的低版本,所以无法找到swagger使用的某个方法了。
// 得到keysList<String> keys = new ArrayList<String>()
// 得到values
List<Integer> values = new ArrayList<Integer>()
// Map
Map<String, Integer> rs = new LinkedHashMap<String, Integer>()
// 确保以最小的list集合长度为rs的长度, 防止 NullPointerException 异常
int keyLen = (keys != null) ? keys.size() : 0
int valLen = (values != null ) ? values.size() : 0
int len = keyLen
if(len > valLen)
Len = valLen
// 保存到Map中, for循环遍历效率较高
for(int i=0 i<len i++)
rs.put(keys.get(i), values.get(i))
希望能帮助你
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)