I want to cache a few of my dao queries. And it works, but cache doesn't expire. What I'm doing wrong?
My ehcache.xml:
<config xmlns='http://www.ehcache.org/v3'
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jsr107="http://www.ehcache.org/v3/jsr107"
xsi:schemaLocation="http://www.ehcache.org/v3 http://www.ehcache.org/schema/ehcache-core-3.0.xsd
http://www.ehcache.org/v3/jsr107 http://www.ehcache.org/schema/ehcache-107-ext-3.0.xsd">
<cache alias="test">
<key-type>java.lang.String</key-type>
<value-type>xxx.model.SignalValueType</value-type>
<expiry>
<ttl unit="seconds">5</ttl>
</expiry>
<resources>
<heap unit="entries">100</heap>
<offheap unit="MB">10</offheap>
</resources>
</cache>
</config>
In application.properties I have entry:
spring.cache.jcache.config=classpath:ehcache.xml
In pom:
<dependency>
<groupId>javax.cache</groupId>
<artifactId>cache-api</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.ehcache</groupId>
<artifactId>ehcache</artifactId>
</dependency>
And my query:
@Cacheable(value = "test", key = "#code")
@Override
public SignalValueType getSignalValueType(String code) {
SignalValueType signalType = (SignalValueType) sf.getCurrentSession()
.createQuery("FROM SignalValueType svt WHERE svt.code = :code").setParameter("code", code)
.uniqueResult();
return signalType;
}
I expect 5 seconds expiring, but after this time (and longer) query is still cached. What I'm doing wrong?