1

次のプロジェクト ディレクトリ構造があります。

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ファイルは、ローカル マシン ( ) でホストされている Artifactory リポジトリの URL リゾルバーを指定しますhttp://localhost:8080/artifactory/myrepo。Ivy が内部で HttpClient を使用しているか (スタックトレースが示唆しているように)、何らかの理由で、同じマシン上の HTTP URL が原因で窒息しているのか疑問に思っています。多分?!?そして、はい、URL が正しく、Ant ビルドを実行している間、Artifactory が実行されていることは確かです!

ここで何が起こっているのか誰にもわかりますか?なぜ<ivy-cleancache>NPEを投げるのですか?そのソース コードを調べていますが、NPE がどこから来ているのか、またはその理由を見つけることができないようです。必要に応じて詳細を提供できます。前もって感謝します!

4

1 に答える 1

0

これに返信したつもりだったのですが、ここに表示されていません...

プロジェクト用の余分な jar を に入れないでください$ANT_HOME/lib。これにはいくつかの理由があります。

  • お気づきのように、オプションのタスクの各セットが必要なクラスパスをセットアップしようとするため、jar の衝突が発生する可能性があります。はい、実行時にクラスパスを設定する必要がないのは良いことですが、<taskdef>それほど悪くはありません。
  • プロジェクトを他の人に譲る場合、ビルドを行う前に、オプションの jar もすべてインストールする必要があります。

より良い方法は、ディレクトリを作成し、${basedir}/ant.libant タスク 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 のクラスパスにあるため、クラスパスを指定しなかった場合は、すべての jar が$ANT_HOME/lib自動的に取得されます。あなたは単にこれを行うことができました:

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

クラスパスは必要ありません。

于 2012-10-21T16:44:13.443 に答える