SSM中整合EhCahce缓存

一、背景

        一个应用程序给用户体验的好坏,其中反应速度的快慢占据相当的比重,反应速度的快慢除了入网速、硬件环境等客观因素外,与程序的质量也有很大关系,那这其中数据的读写操作就是影响因素之一。
        一般像经常读取、使用的数据我们都会采取缓存的策略以调高代码的运行速度,mybatis中也有相应的缓存机制。其中一级缓存是session级别的,不同session间无法共享,并且session flush或者close后缓存就会清除。二级缓存则是mapper级别,不同色session可以共享,可以使用自定义的缓存机制,例如Ehcahce。

二、EhCahce简单介绍

        Ehcahce是一个基于内存的缓存框架,简单、快速、精干,但是主要还是应用于应用缓存(进程内缓存),缓存中以key-value形式存储数据。

三、Ehcahce的使用

        首先我这里利用maven构建一个SSM工程,具体步骤这里不做介绍。整合Ehcahce分以下几步:

1、添加依赖

在原有基础上添加一下依赖

		<!-- 添加spring依赖时加上 -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context-support</artifactId>
			<version>${springframework.version}</version>
		</dependency>

		<!-- ehCahce缓存 -->
		<dependency>
			<groupId>org.mybatis.caches</groupId>
			<artifactId>mybatis-ehcache</artifactId>
			<version>1.1.0</version>
		</dependency>
		<dependency>
			<groupId>org.ehcache</groupId>
			<artifactId>ehcache</artifactId>
			<version>3.4.0</version>
		</dependency>
		<dependency>
			<groupId>net.sf.ehcache</groupId>
			<artifactId>ehcache-core</artifactId>
			<version>2.4.8</version>
		</dependency>
2、ehcahce.xml配置文件

在工程resources目录下(随个人)创建ehcahce.xml文件,具体的属性简单介绍一下,
cache元素的属性:

  • name:缓存名称
  • maxElementsInMemory:内存中最大缓存对象数
  • maxElementsOnDisk:硬盘中最大缓存对象数,若是0表示无穷大
  • eternal:true表示对象永不过期,此时会忽略timeToIdleSecondsh和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属性,才有 意义
<?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">
   <!-- 指定一个文件目录,当EhCache把数据写到硬盘上时,将把数据写到这个文件目录下 -->
    <diskStore path="D:\cahce"/>
	
	<!--默认缓存策略-->
	<defaultCache 
		eternal="false" 
		maxElementsInMemory="1000"
		overflowToDisk="false" 
		diskPersistent="false" 
		timeToIdleSeconds="0"
		timeToLiveSeconds="600" 
		memoryStoreEvictionPolicy="LRU" />
	
	<!--自定义缓存策略-->
	<cache 
		name="demo" 
		eternal="false" 
		maxElementsInMemory="100"
		overflowToDisk="false" 
		diskPersistent="false" 
		timeToIdleSeconds="0"
		timeToLiveSeconds="300" 
		memoryStoreEvictionPolicy="LRU" />
</ehcache>

其中自定义缓存中name属性是当前这个缓存的标识,在使用缓存的地方就会用到。

3、mybatis相关配置文件设置
(1)mybatis配置文件开启缓存策略
	<settings>
		<!-- 表示开启缓存 -->
		<setting name="cacheEnabled" value="true" />
		
		<!-- 表示是否开启自动驼峰命名规则 -->
		<setting name="mapUnderscoreToCamelCase" value="true" />

		<!-- 设置在控制台输出日志 -->
		<setting name="logImpl" value="STDOUT_LOGGING" />
	</settings>
(2)在相应的mapper中配置

在需要使用缓存的mapper中添加如下代码:

	<!--在mapper文件中引入缓存策略-->
    <cache type="org.mybatis.caches.ehcache.LoggingEhcache"/>

type=“org.mybatis.caches.ehcache.LoggingEhcache” 表示打印log。

4、applicationcontext.xml

在spring的配置文件中配置:

	<!-- 开启spring缓存注解 -->
    <cache:annotation-driven cache-manager="ehCacheCacheManager" />  
	
	<!-- ehcahce -->
	<bean id="myehcahce" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
		<!--找到ehcache.xml配置文件的位置-->
    	<property name="configLocation" value="classpath:ehcache.xml"/>
	</bean>
	<bean id="ehCacheCacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
		<property name="cacheManager" ref="myehcahce"/>
	</bean>
5、controller代码
	/* @Cacheable(cacheNames="cacheTest"):cacheNames的属性值对应ehcahce中自定义缓存的name,
	 *  在查询时,会先在缓存中查找数据,当缓存中数据不存在时,才会执行之后方法查找数据库
	 */
	@Cacheable(cacheNames="demo",key="users")
	@RequestMapping("/get")
	public void get() {
		List<User> all = userSerivce.getAll();
		System.out.println(all);
	}
	
	/* @CacheEvict(cacheNames="cacheTest",key="users"):
	 * 在执行增删改操作时,为了保证缓存和数据库信息一致性,会将缓存信息清空。
	 * 然后通过key属性重新加入缓存
	 */
	@CacheEvict(cacheNames="demo",key="users")
	@RequestMapping("/update")
	public void update() {
	}

四、测试

通过页面访问查询接口通过观察日志就可以看到缓存效果
第一次查询:
首次

第二次查询
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值