现象:
简单实用Cache二级缓存 在程序内存中缓存自己的信息
实用范围:
适合数据库查询某些基本不会变动才参数,将参数存入缓存,下次查询直接在缓存中获取,将提高查询速度
缺点:
不适应变动的参数
方法:
(1)引入jar包
将ehcache-2.10.3.jar 和 slf4j-api-1.7.13两个jar包引入
(2)将ehcache.xml文件复制到项目classpath路径下 根据需要修改配置文件。内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd" updateCheck="false">
<!-- 设置缓存磁盘路径-->
<diskStore path="${java.io.tmpdir}/FreeMarker_cache" />
<!--
cache元素的属性:
name:缓存名称
maxElementsInMemory:内存中最大缓存对象数
maxElementsOnDisk:硬盘中最大缓存对象数,若是0表示无穷大
eternal:true表示对象永不过期,此时会忽略timeToIdleSeconds和timeToLiveSeconds属性,默认为false
overflowToDisk:true表示当内存缓存的对象数目达到了
maxElementsInMemory界限后,会把溢出的对象写到硬盘缓存中。注意:如果缓存的对象要写入到硬盘中的话,则该对象必须实现了Serializable接口才行。
diskSpoolBufferSizeMB:磁盘缓存区大小,默认为30MB。每个Cache都应该有自己的一个缓存区。
diskPersistent:是否缓存虚拟机重启期数据,是否持久化磁盘缓存,当这个属性的值为true时,系统在初始化时会在磁盘中查找文件名 为cache名称,后缀名为index的文件,这个文件中存放了已经持久化在磁盘中的cache的index,找到后会把cache加载到内存,要想把 cache真正持久化到磁盘,写程序时注意执行net.sf.ehcache.Cache.put(Element element)后要调用flush()方法。
diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认为120秒
timeToIdleSeconds: 设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,如果处于空闲状态的时间超过了timeToIdleSeconds属性 值,这个对象就会过期,EHCache将把它从缓存中清空。只有当eternal属性为false,该属性才有效。如果该属性值为0,则表示对象可以无限 期地处于空闲状态
timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存中后,如果处于缓存中的时间超过了 timeToLiveSeconds属性值,这个对象就会过期,EHCache将把它从缓存中清除。只有当eternal属性为false,该属性才有 效。如果该属性值为0,则表示对象可以无限期地存在于缓存中。timeToLiveSeconds必须大于timeToIdleSeconds属性,才有 意义
memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。可选策略有:LRU(最近最少使用,默认策略)、FIFO(先进先出)、LFU(最少访问次数)。
-->
<!-- 默认缓存 -->
<defaultCache
maxEntriesLocalHeap="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
maxEntriesLocalDisk="10000000"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"/>
<cache name="prepaySecretCheck"
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="3600"
timeToLiveSeconds="3600"
overflowToDisk="false"
memoryStoreEvictionPolicy="LRU"/>
</ehcache>
(3)将开启缓存注解复制到bean.xml文件下,内容如下:
<!-- 写入bean.xml开启缓存标签-->
xmlns:cache="http://www.springframework.org/schema/cache"
http://www.springframework.org/schema/cache
http://www.springframework.org/schema/cache/spring-cache-4.3.xsd
<!-- 写入bean.xml文件 开启缓存-->
<bean id="ehcache" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
<property name="configLocation" value="classpath:ehcache.xml"/>
</bean>
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
<property name="cacheManager" ref="ehcache"/>
</bean>
<!-- 启用缓存注解开关 -->
<cache:annotation-driven cache-manager="cacheManager"/>
(4):在程序中使用缓存
@Service
public class LogServiceImpl implements LogService{
@Autowired
private LogMapper logMapper;
@Autowired
private CacheManager cacheManager; //自动注入缓存对象
@Override
public List<Log> findList() {
Cache cache = cacheManager.getCache("prepaySecretCheck"); //根据名称获取缓存对象
Element element = cache.get("list"); //获取缓存中的值
if(element!=null){
List<Log> list = (List<Log>) element.getObjectValue();
return list;
}
PageHelper.startPage(1, 5,"id desc");
List<Log> selectByExample = logMapper.selectByExample(null);
cache.put(new Element("list", selectByExample)); //将值存入缓存
PageInfo<Log> pageInfo = new PageInfo<Log>(selectByExample);
return selectByExample;
// return null;
}
}
注意事项:
缓存以键值对的方式存储,如果每个用户使用的数据不一样,得使用与每个用户相关的内容作为缓存的key,保证每个用户得到的数据都是自己的数据!