1

Grails 2.1.0 を使用しています。L2 キャッシュを検証/プロファイリングしようとしています。今、休止状態/キャッシュの設定が正しいとは思えません。

• conf\DataSource.grooy にある hibernate 設定で generate_statistics を有効にしました。

hibernate {
    generate_statistics = true
    cache.use_second_level_cache = true
    cache.use_query_cache = true
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory'
    format_sql = true
    use_sql_comments = true
}

• ドメイン マッピングでキャッシュを有効にしました。

package com.att.failbox.log.cause
class LogCauseMemento {
    Date dateCreated
    static mapping = {
        version false
        id generator: 'assigned'
        table 'log_cause'
        cache: true
    }
}

• ehcache.xml のドメイン エントリに対応するエントリを追加しました。

<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:noNamespaceSchemaLocation="ehcache.xsd" >
<diskStore path="java.io.tmpdir"/>
<cacheManagerEventListenerFactory class="" properties=""/>
<defaultCache
    eternal="false"
    timeToLiveSeconds="3600"
    overflowToDisk="false"
    diskPersistent="false"
    />
<cache name="com.att.failbox.log.cause.LogCauseMemento"
    maxElementsInMemory="100000"
    eternal="true"
    />
</ehcache>

• しかし、「stats.getSecondLevelCacheRegionNames()」を使用して L2 キャッシュを検証しようとすると、「StandardQueryCache、UpdateTimestampsCache」しか得られません。

import org.hibernate.stat.Statistics
class DomainProfilerService {
    def sessionFactory
    def displayStatistics() {
        Statistics stats = sessionFactory.getStatistics()
        def names = stats.getSecondLevelCacheRegionNames()
        names.each(){ println it }
    }
}

L2 キャッシュを検証するために正しい場所を調べていますか?

4

0 に答える 0