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 }
}
}