16

在我的 Spring + Hibernate 项目中,我使用 SLF4J 1.6.4 和 LogBack 进行日志记录。现在,我添加了 Ehcache 2.2.0(通过 ehcache-spring-annotations-1.1.3)。缓存似乎作为方法工作,用@Cacheable 注释,不再被执行,尽管返回正确的结果。但是,我有兴趣查看 Ehcache 编写的日志。由于 Ehcache 也使用 SLF4J,我想,应该将日志写入我的日志文件。但是,这并没有发生。logback.xml 有以下内容。

 <root level="info">
    <appender-ref ref="STDOUT"/>
    <appender-ref ref="ROLLING"/>
</root>

添加以下内容也无济于事

 <logger name="net.sf.ehcache"> 
</logger> 

ehcache.xml

    <cache name="sampleCache1"
       eternal="false"
       overflowToDisk="true"
       timeToIdleSeconds="300"
       timeToLiveSeconds="600"           
       memoryStoreEvictionPolicy="LFU"           
        />

请建议我克服这个问题。

Ehcache 使用的是 SLF4J 1.6.1,而我的项目使用的是 SLF4J 1.6.4。它会引起任何问题吗?

谢谢

4

4 回答 4

54

DEBUGEhCache 在级别上记录了很多。首先,此配置片段过滤掉以下所有日志记录语句INFO

<root level="info">

将其更改为

<root level="ALL">

第二

<logger name="net.sf.ehcache">

需要提高日志记录级别

<logger name="net.sf.ehcache" level="ALL"/> 

然后,您应该会看到来自 EhCache(和其他)的大量日志记录语句。

于 2012-05-22T16:17:51.877 回答
14

在我看来,将根记录器级别设置ALL为不是一个好主意。

这意味着ALL每个级别的日志消息都将通过(除非您在附加程序上设置阈值)。

相反,我建议您设置一个合理的根 logger 级别,例如INFOor WARN,然后如果您需要更具体的信息,请设置各个 logger 的日志级别。

这样,您就不会创建不必要的信息森林。

我建议如下:

<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender"> 
  <param name="Target" value="System.out"/> 
  <layout class="org.apache.log4j.PatternLayout"> 
    <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
  </layout>  
</appender> 

<logger name="net.sf.ehcache">
  <level value="DEBUG"/>
</logger>

<root> 
  <priority value ="INFO" /> 
  <appender-ref ref="CONSOLE" /> 
</root>

于 2015-09-24T15:31:28.317 回答
5

我还发现启用 DEBUG 登录很方便,org.springframework.cache因为我使用的是 Spring Framework 4.2.1 的缓存功能(@Cacheable 等)。

于 2015-09-17T08:39:30.670 回答
3

我通过实现 CacheEventListener 接口为 Ehcache 3 编写了一个自定义记录器,如下所示

public class CacheLogger implements CacheEventListener<Object, Object> {

    private static final Logger LOG = LoggerFactory.getLogger(CacheLogger.class);

    @Override
    public void onEvent(CacheEvent<?, ?> cacheEvent) {
        LOG.info("YOUR LOG IS HERE");
    }
}

ehcache.xml 将定义监听器类

<cache-template name="default">
        <expiry>
            <ttl unit="seconds">300</ttl>
        </expiry>
        <listeners>
            <listener>
                <class>com.path.to.CacheLogger</class>
                <event-firing-mode>ASYNCHRONOUS</event-firing-mode>
                <event-ordering-mode>UNORDERED</event-ordering-mode>
                <events-to-fire-on>CREATED</events-to-fire-on>
                <events-to-fire-on>EXPIRED</events-to-fire-on>
                <events-to-fire-on>EVICTED</events-to-fire-on>
            </listener>
        </listeners>
        <resources>
            <heap>1000</heap>
            <offheap unit="MB">10</offheap>
        </resources>
    </cache-template>
于 2020-03-12T13:22:50.813 回答