6

我有一个构建文件,作为构建过程的一部分,它依赖于几个 taskdef。这些 taskdef 项(例如,webdoclet 和 jasper2)使用 log4j 作为记录器。理想情况下,我希望能够为每个提供不同的 log4j 配置文件,但至少,我希望能够指定使用哪个 log4j 配置文件。

我过去所做的是将包含我希望 taskdef 使用的 log4j.xml 的目录放在类路径的前面。例如:

<目标名称="define.jasper2">
  <path id="jspc.classpath">
      <!-- 把这个放在第一位,这样 Jasper 就会在 Build 目录中找到 log4j.xml -->
      <pathelement location="构建"/>
      <fileset dir="${tomcat.libs}">
             ……
      </文件集>
      <pathelement location="${log4j.jar}"/>
      ……
  </路径>

  <taskdef name="jasper2" classname="org.apache.jasper.JspC" classpathref="jspc.classpath"/>
</目标>

我已经验证,事实上,“Build”目录位于类路径的前面,并且该目录中存在 log4j.xml。但是,当我在调试中使用 log4j 以详细模式运行 ant 时,我看到 log4j 正在选择当前工作目录中的 log4j.xml ,这不是我想要的。Log4j 似乎没有使用类路径来解析默认的 log4j.xml。

我正在使用 log4j 1.2.8(嵌入在更大的框架中,所以我无法升级它)并且其中一些任务定义似乎依赖于 commons-logging 1.0.3。构建过程使用 Sun Java 5。

如果我set ANT_OPTS=-Dlog4j.configuration=Build/log4j.xml在运行 ant 之前,taskdefs 会正确加载所需的 log4j.xml。

将“Bu​​ild”目录放在用于工作的 taskdef 的类路径的前面。我不知道发生了什么变化。如何恢复我可以控制的行为——在 build.xml 中——哪个 log4j 配置文件用于给定任务?除了设置 ANT_OPTS 和重新排列文件以将应用程序的 log4j.xml 移出当前工作目录以使 log4j 找到正确的 log4j.xml 文件之外,还有其他方法吗?

4

4 回答 4

4

我可以使用相对文件 URL 指定配置文件,sysproperty如下所示:

<java classname="com.lunatech.MainClass">
   <sysproperty key="log4j.configuration" value="file:src/log4j-debug.properties"/>
   <classpath refid="runtime.classpath"/>
</java>
于 2009-08-10T20:32:50.963 回答
2

Log4j 通过查找系统属性 log4j.configuration 来加载其配置。否则,它会在类路径中查找 log4j.properties 或 log4j.xml。

在一些 fork 新 JVM 的 ant 任务上,您可以使用 <jvmarg/> 标记指定 log4j.configuration 系统属性。然而,对于那些你最好的选择是创建一个类路径条目,其第一个条目是你想要使用的 log4j 配置。

于 2009-01-26T23:42:13.463 回答
0

如果我在运行 ant 之前设置 ANT_OPTS=-Dlog4j.configuration=Build/log4j.xml,taskdefs 会正确加载所需的 log4j.xml。

您是否尝试过使用 sysproperty 设置此属性?

应该看起来像这样:

<target name="define.jasper2">
   <sysproperty key="log4j.configuration" value="Build/log4j.xml"/>
   ...
</target>
于 2009-01-30T21:21:53.270 回答
0

您可以移动当前工作目录中的 log4j.xml 文件吗?

于 2009-01-26T23:37:48.217 回答