gpt4 book ai didi

java - Ivy 清理缓存任务抛出 NullPointEreException

转载 作者:行者123 更新时间:2023-12-01 05:05:50 26 4
gpt4 key购买 nike

我有以下项目目录结构:

MyProject/
src/main/java/
All of my Java sources
build/
build.xml
build.properties
ivy.xml
ivy-settings.xml
ivy-settings.properties

build.xml看起来像这样:

<project name="MyProject" default="audit" basedir=".." xmlns:ivy="antlib:org.apache.ivy.ant">
<property file="build/build.properties"/>
<property environment="env"/>

<path id="ant.lib.path">
<fileset dir="${env.ANT_HOME}/lib" includes="*.jar"/>
</path>

<taskdef resource="org/apache/ivy/ant/antlib.xml" uri="antlib:org.apache.ivy.ant" classpathref="ant.lib.path"/>

<target name="configIvy">
<echo message="Configuring Ivy."/>
<echo message="URL is: ${ivy.settings.home}"/>
<ivy:settings url="${ivy.settings.home}"/>

<!-- Clear/flush the Ivy cache. -->
<echo message="Cleaning the local Ivy cache for the current build."/>
<ivy:cleancache/>
</target>
</project>

当我运行ant -buildfile /<path-to-my-project>/MyProject/build/build.xml configIvy时,我得到以下控制台输出:

Buildfile: /<path-to-my-project>/MyProject/build/build.xml

configIvy:
[echo] Configuring Ivy.
[echo] URL is: file:////<path-to-my-project>/MyProject/build/ivy-settings.xml
[ivy:cleancache] :: Apache Ivy 2.3.0-rc1 - 20120416000235 :: http://ant.apache.org/ivy/ ::

BUILD FAILED
/<path-to-my-project>/MyProject/build/build.xml:85: java.lang.ExceptionInInitializerError
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at org.apache.ivy.util.url.URLHandlerRegistry.getHttp(URLHandlerRegistry.java:47)
at org.apache.ivy.ant.IvyAntSettings.configureURLHandler(IvyAntSettings.java:367)
at org.apache.ivy.ant.IvyAntSettings.createIvyEngine(IvyAntSettings.java:267)
at org.apache.ivy.ant.IvyAntSettings.getConfiguredIvyInstance(IvyAntSettings.java:237)
at org.apache.ivy.ant.IvyTask.getIvyInstance(IvyTask.java:92)
at org.apache.ivy.ant.IvyTask.prepareTask(IvyTask.java:256)
at org.apache.ivy.ant.IvyTask.execute(IvyTask.java:276)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:392)
at org.apache.tools.ant.Target.performTasks(Target.java:413)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
at org.apache.tools.ant.Main.runBuild(Main.java:811)
at org.apache.tools.ant.Main.startAnt(Main.java:217)
at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
Caused by: java.lang.NullPointerException
at org.apache.log4j.Category.isDebugEnabled(Category.java:129)
at org.apache.commons.logging.impl.Log4JLogger.isDebugEnabled(Log4JLogger.java:239)
at org.apache.commons.httpclient.HttpClient.<clinit>(HttpClient.java:69)
... 25 more

我的ivy-settings.xml文件指定托管在我的本地计算机 ( http://localhost:8080/artifactory/myrepo ) 上的 Artifactory 存储库的 URL 解析器。我想知道 Ivy 是否在幕后使用 HttpClient (如堆栈跟踪所示),并且由于某种原因,是否因为它是同一台机器上的 HTTP URL 而令人窒息?或许?!? 是的,我确信 URL 是正确的,并且在我运行 Ant 构建时 Artifactory 正在运行!

有人能发现这里发生了什么吗?为什么会<ivy-cleancache>扔一个NPE?我正在查看它的源代码,似乎无法找到 NPE 的来源或原因。如果需要,我可以提供更多详细信息。提前致谢!

最佳答案

我以为我对此做出了回应,但我在这里没有看到它......

不要将项目的额外 jar 放入 $ANT_HOME/lib 。造成这种情况的原因有以下几个:

  • 正如您所发现的,当每组可选任务尝试设置它们所需的类路径时,可能会出现 jar 冲突。是的,当您执行 <taskdef> 时不必设置类路径,这很好。 ,但情况并没有那么糟糕。
  • 如果您将项目交给其他人,他们也必须先安装所有可选的 jar,然后才能进行构建。

更好的方法是创建 ${basedir}/ant.lib目录,然后将每组 ant 任务 jar 放在自己的子目录中。例如,您将 Ivy jar 放入 ${basedir}/ant.lib/ivy然后你将 Checkstyle jar 放入 ${basedir}/ant.lib/checkstyle 。然后,使用指向该目录的类路径定义taskdef,如下所示:

 <taskdef resource="org/apache/ivy/ant/antlib.xml" 
uri="antlib:org.apache.ivy.ant">
<classpath>
<fileset dir="${basedir}/lib/ivy"/>
</classpath>
</taskdef>

这样,Ivy 就不会拿起错误的 jar 。作为奖励,您还可以将您的项目提供给其他人,并且 Ivy 已经安装并为他们运行。他们无需下载 Ivy 并在正确的类路径中设置 jar。

顺便说一下,$ANT_HOME/lib已经在 Ant 类路径中,因此如果您没有指定类路径,则 $ANT_HOME/lib 中的所有 jars将会被自动拾取。你可以简单地这样做:

 <taskdef resource="org/apache/ivy/ant/antlib.xml" 
uri="antlib:org.apache.ivy.ant"/>

不需要类路径。

关于java - Ivy 清理缓存任务抛出 NullPointEreException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12690035/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com