对于standalone.xml中配置的logger,可以找到log4j no appender

时间:2013-04-19 16:57:47

标签: logging log4j jboss7.x

我在独立模式下使用jboss作为7。我在我的应用程序中使用spring,当我运行我的应用程序时,我在服务器日志中收到以下错误:

17:40:19,669 ERROR [stderr] (http-localhost-127.0.0.1-8080-1) log4j:WARN No appenders could be found for logger (org.springframework.core.env.StandardEnvironment).
17:40:19,671 ERROR [stderr] (http-localhost-127.0.0.1-8080-1) log4j:WARN Please initialize the log4j system properly.  

所以我通过添加记录器来配置jboss如下:

        <logger category="org.springframework.core.env.StandardEnvironment">
            <level name="DEBUG"/>
            <handlers>
                <handler name="CONSOLE"/>
                <handler name="FILE"/>
                <handler name="TESTFILE"/>
            </handlers>
        </logger>  

处理程序CONSOLE定义如下:

    <console-handler name="CONSOLE" autoflush="true">
        <level name="DEBUG"/>
        <formatter>
            <pattern-formatter pattern="%d{HH:mm:ss,SSS} %-5p [%c] (%t) %s%E%n"/>
        </formatter>
    </console-handler> 

但即便这样做后我仍然收到同样的错误,为什么?

解决方案:

缺少的部分是指示应用程序应该使用jboss的子系统logging作为(log4j)位于modules目录org/apache/log4j更准确地位于jboss-deployment-structure.xml中。这是通过将文件<jboss-deployment-structure> <deployment> <dependencies> <module name="org.apache.log4j"/> </dependencies> </deployment> </jboss-deployment-structure> 添加到包含以下内容的WEB-INF来完成的:

{{1}}

1 个答案:

答案 0 :(得分:0)

你必须在你的配置中定义一个appender:

<appender name="springFileAppender" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="../logs/spring.log" />
    <param name="datePattern" value="yyyy-MM-dd" />
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%d{dd-MM-yyyy kk:mm:ss.SSS} %-5p %c %x - %m%n" />

    </layout>
</appender>

然后从记录器中引用它:

<logger name="org.springframework.beans" additivity="true">
    <level value="info" />
    <appender-ref ref="springFileAppender" />
</logger>

此配置会记录Spring Beans模块中的所有内容,并在文件中记录INFO阈值../ logs / spring.log

编辑:我明白了,你正在使用带有JBOSS的log4J!

然后你应该定义处理程序(就像我的例子中的appender)。

类似的东西:

 <periodic-rotating-file-handler name="FILE">
            <level name="DEBUG"/>
            <formatter>
                <pattern-formatter pattern="%d{HH:mm:ss,SSS} %-5p [%c] (%t) %s%E%n"/>
            </formatter>
            <file relative-to="jboss.server.log.dir" path="server.log"/>
            <suffix value=".yyyy-MM-dd"/>
            <append value="false"/>
    </periodic-rotating-file-handler>