Maven常见问题和陷阱

喜欢它还是讨厌它(很多人似乎都讨厌它), Maven是64%的Java开发人员广泛使用的工具(来源– 2014年Java工具和技术前景 )。

大多数经验丰富的开发人员已经对Maven感到头疼。 通常以困难的方式,用头撞到砖墙上。 不幸的是,我感到新开发人员正在经历同样的艰苦学习过程。

纵观世界各地的主要Java会议,您都找不到任何与Maven相关的会议,这些会议都可以指导您了解基础知识。 也许社区认为您应该已经了解它们,就像Java语言本身一样。 尽管如此,回收这些知识可能对每个人都是双赢的情况。 您或您的队友浪费了多少时间不知道如何处理Maven的特殊性?

如果您正在阅读本文,我还将假设您掌握了Maven的基础知识。 如果没有,请查看以下文章:

  • 5分钟内完成Maven
  • 构建生命周期简介

还有很多其他文章。 我认为添加自己的内容,重复相同的内容没有任何价值,但是如果我有需要,可以写一个。 让我知道您是否支持!

无论如何,我认为我可以通过指出团队在使用Maven时遇到的主要问题,对其进行解释以及如何解决这些问题来增加一些价值。

为什么这个罐子在我的建筑物中?

由于采用了Maven传递依赖机制,因此所包含库的图可以很快变得很大。

如果您在类路径中看到某些东西,但没有将其放在那儿,则很可能是由于传递依赖。 您可能需要它,也许不需要。 也许您正在使用的库代码的一部分不需要所有这些额外的jar。 在这里感觉像是一场赌博,但是如果使用mvn dependency:analyze ,您可能会有一个大概的想法。 该命令将告诉您项目实际使用了哪些依赖项。

我主要在这里进行反复试验,排除我认为不需要的内容,然后运行代码以查看一切是否正常。 不幸的是,该命令并没有告诉您所使用的依赖项是否确实需要传递依赖项。 嘿,如果有人知道更好的方法,请告诉我!

我看不到我的变化!

可能由于多种原因而发生。 让我们看一下最常见的:

依赖关系未在本地存储库中构建

您可能具有模块A和模块B。模块B对模块A具有依赖性。对模块B所做的更改在模块A中不可见。

发生这种情况是因为Maven调查了它自己的本地jar存储库,以将其包含在classpath中。 如果进行任何更改,则需要将新jar的副本放入本地存储库。 您可以通过在更改后的项目中运行mvn install来实现。

依赖版本不正确

可以很简单地更改您正在使用的依赖项的版本,或者弄清楚该依赖项确实很麻烦。 当Maven执行依赖关系查找时,它将使用规则“最近定义优先”。 这意味着在依赖关系树中,所使用的版本将是最接近您项目的版本。 困惑? 我也是。让我们尝试一个例子。

您想在项目A使用依赖项Dv1 ,但您正在获取Dv2 ,并且具有以下依赖项树:

A -> B -> C -> Dv1

A -> E -> Dv2

包括D哪个依存关系? Dv1还是Dv2 ? 在Dv2情况下,由于“最近定义优先”规则。 如果两个依赖关系版本在依赖关系树中的深度相同,则最重要的是声明中的顺序。

要解决此问题,您可以在A Dv1中显式添加一个依赖Dv1 ,以强制使用Dv1或仅排除Dv2

如果使用命令mvn dependency:tree ,它将输出一棵树,其中将包含项目的所有依赖关系和版本。 这对于调试此类问题非常有帮助。

远程存储库已覆盖您的更改

公司通常会拥有一个内部Maven存储库,以缓存工件,存储版本或提供您正在处理的项目的最新更改。 在大多数情况下,这很有效,但是当您使用SNAPSHOT版本时, Maven总是尝试获取对该依赖项的最新更改。

现在,您很高兴地在对Project B更改,该更改依赖于Project A 您在本地构建所有内容,然后继续将更改集成到Project A 。 有人或上载新的SNAPSHOT版本的Project B 请记住,您所做的更改尚不可见,因为您已将所有内容都保存在本地并且尚未提交到VCS。 您对Project A进行的下一个构建将从公司存储库中选择Project B ,而不是从本地存储库中选择Project B

该罐子不包括在分发中!

为了增加一些混乱,让我们谈谈范围。 Maven有四个作用域: compileprovidedruntimetest 。 每个依赖项都有一个范围,该范围为您的应用程序定义了不同的类路径。

如果缺少某些内容,并假设正确定义了依赖项,则问题很可能出在范围之内。 compile安全考虑,请使用compile范围(这是默认设置)。 命令mvn dependency:analyzemvn dependency:tree在这里也可以为您提供帮助。

找不到工件!

啊,可怕的是“无法解决依赖关系……无法找到工件”。 这就像Java NPE! 发生这种情况的原因有很多。 还有其他一些明显的证据,但无论如何还是要调试的。 我通常会按照以下清单尝试解决此问题:

  • 检查依赖项是否正确定义
  • 检查您是否指向存储依赖项的正确远程存储库
  • 检查远程存储库是否真正拥有依赖项!
  • 检查您是否拥有最新的pom.xml文件
  • 检查罐子是否损坏
  • 检查公司存储库是否正在缓存Internet存储库,并且没有发出获取新库的请求
  • 检查依赖项定义是否被某些内容覆盖。 使用mvn help:effective-pom进行构建项目的实际Maven设置
  • 不要使用-o

结论

Maven并不是一个完美的工具,但是,如果您了解一些技巧,它将帮助您并节省调试构建问题的时间。 还有其他方法可以解决其中一些问题,但是我所掌握的知识不足以表达我对这些问题的看法。

无论如何,大量的项目使用Maven作为构建工具,我相信开发人员应该了解他们的构建工具,以便能够在日常工作中表现更好。 希望这篇文章对您有用。

随时发布此处未涵盖的任何其他问题。 不幸的是, Maven有时似乎充满了惊喜。

最后一条建议:永远不要信任IDE! 如果它可以在命令行上运行,那就是IDE的问题!

翻译自: https://www.javacodegeeks.com/2014/09/maven-common-problems-and-pitfalls.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/362324.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Oracl数据库中大数据的备份-1

起原:chinaitlab  问:公司里的oracle数据库有20G之大(这是一个方案的大小.原本这个方案有30G,我已经把能删的数据都删了),怎样备份?觉得备份一次好慢啊.专家有什么指导一下的吗?(另:20G的数据库是不是备份也要20G多么?)我搁浅能每周备份一次,最好天…

js 值和引用

1、概述 简单值&#xff08;基本类型&#xff09;通过值复制的方式来赋值/传递。 复合值&#xff08;对象&#xff09;通过引用复制的方式来赋值/传递。 <!DOCTYPE html><html lang"zh"><head><meta charset"UTF-8" /><title…

js笔记(六)事件、正则

数组方法、字符串方法总结 大标题小节一、事件1.1 事件&#xff1b;1.2 事件对象&#xff1b;1.3 键盘事件的keyCode&#xff1b;1.4 关于鼠标的尺寸&#xff1b;1.5 事件冒泡&#xff1b;1.6 事件的默认行为&#xff1b;1.7 事件监听&#xff1b;1.8 事件委托&#xff08;事件…

Hazelcast入门指南第3部分

这是从初学者的角度来看一系列有关如何使用Hazelcast的文章的延续。 如果您还没有阅读最后两个&#xff0c;我鼓励您阅读它们&#xff1a; Hazelcast入门指南第1部分 Hazelcast入门指南第2部分 原始人来了 在上一篇文章中&#xff0c;我提到将ILock与IList和ISet一起使用&am…

Windows与Linux下进程间通信技术比较

一般我们写的程序都是以单个进程的方式来运行的&#xff0c;比较少涉及到多进程。特别是在windows下&#xff0c;因为Windows是按照线程来分配CPU时间片的&#xff0c;线程是最小的调度单位&#xff0c;所以在Windows下更多的用到多线程&#xff0c;在同一个进程里创建多个线程…

JSONP 原理

HTML 中 script 标签可以加载其他域下的js&#xff0c;比如我们经常引入一个其他域下线上cdn的jQuery。那如何利用这个特性实现从其他域下获取数据呢&#xff1f; 可以先这样试试&#xff1a; <script src"http://api.jirengu.com/weather.php"></script&g…

最长公共前缀(lca+trie树)

问题描述 给出一些串&#xff0c;多组询问求两个串的最长公共前缀。字符串总长 < 10^6。 输入格式 第一行一个整数n&#xff0c;表示字符串的个数。 接下来n行&#xff0c;每行一个字符串&#xff08;字符串不含空格&#xff09;。 第n2行一个整数m&#xff0c;表示询问总数…

vue笔记(三)生命周期、组件(嵌套)、数据传递

生命周期文档 一、生命周期 1、参考一 2、参考二 二、自定义组件 1. 使用&#xff1a;<组件名></组件名> 2. 定义组件&#xff1a; &#xff08;1&#xff09;方法一&#xff1a;官网 let 组件变量名 Vue.extend({template:<div class"header"&…

实用程序类的OOP替代

实用程序类&#xff08;也称为帮助程序类&#xff09;是仅具有静态方法且不封装任何状态的“结构”。 StringUtils &#xff0c; IOUtils &#xff0c; FileUtils从Apache的共享 ; Guava的 Iterables和Iterators以及JDK7的Files是实用程序类的完美示例。 这种设计思想在Java世…

神州泰岳2050万元收买并增资奇点国际

网易科技讯 3月7日消息&#xff0c;神州泰岳来日诰日颁布发表关照公告&#xff0c;将经由股权让渡体例共付出1450万元股权让渡款获得奇点国际100%股权&#xff0c;同时神州泰岳与邵起明分别出资600万元、200万元对奇点国际举行增资。本次增资后&#xff0c;奇点国际注册资金增进…

Vue 状态管理 Vuex

1、概述 Vuex作为插件&#xff0c;管理和维护整个项目的组件状态。 2、安装vuex cnpm i --save vuex 3、vuex使用 github地址&#xff1a;https://github.com/MengFangui/Vuex new Vue({el: #app,router: router,//使用vuexstore: store,render: h > {return h(App)}}); …

拯救你丢失的精度——BigInteger和BigDecimal类(入门)

第三阶段 JAVA常见对象的学习 BigInteger和BigDecimal类 BigInteger类 (一) 构造方法&#xff1a; //针对超过整数范围的运算(整数最大值&#xff1a;2147483647) BigInteger(String val) (二) 常用方法&#xff1a; //加 public BigInteger add(BigInteger val) //减 public…

vue笔记(四)注册组件,路由,vuex

官网 一、项目中的组件注册 二、路由 三、vuex 一、项目中的组件注册 1. 全局 import Loading from /components/loading;//封装的loading组件 Vue.component(Loading,Loading);2. 局部 <loading/>important loading from ./components/loadingcomponents:{loading}二…

#102030:在30天内运行20 10K,庆祝Java 20年

1995年5月23日是技术史上的重要时刻。 业界似乎并没有意识到当天发布的语言会在未来几年内完全改变技术的格局。 Java将在今年的同一天庆祝20岁生日。 Java 20年&#xff0c;哇&#xff01; 回顾20年前的存储器时代&#xff0c;思考一下Java的发明时间/方式。 万维网专用于精…

Java第二次实训

/*3、按要求编写一个Java应用程序&#xff1a; &#xff08;1&#xff09;定义一个类&#xff0c;描述一个矩形&#xff0c;包含有长、宽两种属性&#xff0c;和计算面积方法。 &#xff08;2&#xff09;编写一个类&#xff0c;继承自矩形类&#xff0c;同时该类描述长方体&am…

vue笔记(一)基本使用、数据检测

vue 官网 Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是&#xff0c;Vue 被设计为可以自底向上逐层应用。 一、基本使用 二、数据检测 一、Vue的思想 MVC【参考 nd的博客园】&#xff1a; 名称描述M&#xff08;…

Hazelcast入门指南第2部分

本文是我开始以Hazelcast &#xff08;分布式内存数据库&#xff09;为特色的系列文章的继续。 如果尚未阅读第一篇文章&#xff0c;请单击此处 。 分布式馆藏 Hazelcast具有许多可用于存储数据的分布式集合。 以下是它们的列表&#xff1a; 清单 我设置 队列 清单 IList是…

防止DISCUZ根域名跳转到forum.php的方法

症状&#xff1a;输入http://www.sn03.com/跳转到www.cn03.com/forum.php&#xff0c;这样有两个不好&#xff0c;1、用户复制时不利于传播&#xff0c;2、两个页面内容的重复对搜索引擎排名不利&#xff0c;如何取消这个呢&#xff1f; 全局-域名设置-应用域名-默认&#xff1…

Hazelcast入门指南第1部分

介绍 我将在Hazelcast上做一个系列。 我从Twitter了解了该产品。 他们决定跟随我&#xff0c;经过对他们所做工作的研究后&#xff0c;我决定跟随他们。 我在推特上说&#xff0c;Hazelcast将是分布式密码破解者的重要Struts。 这引起了一些兴趣&#xff0c;我决定加入一个。 H…

Vue 组件与复用

&#xff08;1&#xff09;全局注册 <!DOCTYPE html><html lang"zh"><head><meta charset"UTF-8" /><title>Vue</title></head><body><div id"app"><my-component></my-compone…