ehcache springboot_Spring Boot集成EhCache缓存

Spring Boot集成EhCache缓存

在Java项目中,很多情况下需要用到缓存。笔者接触过的缓存框架有EhCache、Redis、MongoDB,可是由于搞不清楚其中的区别,曾经面试过一些公司被问到EhCache和Redis的区别是什么?为什么项目中用到了EhCache二级缓存,却又用到了Redis,其中的区别是什么?当时由于技术储备有限,未能正确回答出这些问题,工作机会也失之交臂。最近一段时间仔细研究了EhCache,这篇文章将从应用的层面讲讲如何在Spring Boot中使用EhCache。

一、使用说明

在一个Spring Boot项目中,引入EhCache依赖,然后在主启动类里面加上@EnableCaching开启缓存机制,然后配置EhCache配置文件,就可以使用EhCache缓存了。

二、引入配置依赖

首先在Maven的pom.xml中加入EhCache依赖:

org.springframework.boot

spring-boot-starter-cache

net.sf.ehcache

ehcache

然后在src/main/resources里面新增加入ehcache.xml,文件,指定缓存空间interfaces,内容如下:

eternal="false"

maxElementsInMemory="100"

overflowToDisk="false"

diskPersistent="false"

timeToIdleSeconds="0"

timeToLiveSeconds="300" memoryStoreEvictionPolicy="LRU" />

指定磁盘缓存位置:

maxElementsInMemory="1000"

overflowToDisk="false"

diskPersistent="false"

timeToIdleSeconds="0"

timeToLiveSeconds="600" memoryStoreEvictionPolicy="LRU" />

完整的代码如下:

其中ehcache.xsd需要在src/main/resources新建文件,内容如下:

00f33fb8077ee12ef15872fde5d9aa4e.png

然后在Spring Boot主启动类加上开启缓存:

8fcc8729f4a675e2cb8718f143960ba5.png

三、业务实现

新建hx_sys_interface_config表,表结构如下:

38a2b3e946544c90f3024ddbfc8a33f6.png

新建SysInterfaceConfig实体类,代码如下:

405602d858abef74f83f75913b7090ad.png

新增MyBatis,DAO层SysInterfaceConfigMapper.java:

0344d34431e3b27e4e951e70f5fd7df1.png

其MyBatis XML映射文件SysInterfaceConfigMapper.xml增删改查代码如下:

05bace8dbb337628bcd1e374e7d918c5.png
b8a798776977862f4a32bf509a084ac2.png
08d0e87307bd40a78bc4ef2a3efd3a38.png

四、引入EhCache缓存

编写SysInterfaceConfigServiceImpl.java在Service层加入缓存标志:

38885e2ee6c7b33239437eba756812fe.png

新增方法,@CacheEvict加入缓存空间interfaces(前面ehcache.xml中配置的缓存空间):

e1a1935e81c3318cb79850e6d0a63170.png

删除方法,从缓存空间@CacheEvic去掉缓存键:

//删除用户数据

@CacheEvict(value = DEMO_CACHE_NAME,key = "'interface_'+#id")//这是清除缓存

@Override

public void delInterfaceConfig(String id)

{

sysInterfaceConfigMapper.delInterfaceConfig(id);

}

更新用户数据,重新设置缓存@CachePut:

//更新用户数据

@CachePut(value = DEMO_CACHE_NAME,key = "'interface_'+#sysInterfaceConfig.getId()")@Override

public void updateInterfaceConfig(SysInterfaceConfig sysInterfaceConfig)

{

sysInterfaceConfigMapper.updateInterfaceConfig(sysInterfaceConfig);

}

从缓存中取出数据,@Cacheable,从缓存空间缓存键取出数据:

@Cacheable(value=DEMO_CACHE_NAME,key="'interface_'+#id")

@Override

public SysInterfaceConfig findInterfaceConfig(String id)

{

return sysInterfaceConfigMapper.findInterfaceConfig(id);

}

五、测试EhCache缓存

开启SQL打印,在application.yml中开启DAO层SQL打印:

b236e6b4cb685d812f5a1d9a52047e44.png

编写Controller层:

1f91aa2f3eeb45fcef3d40b89df4845a.png

测试插入缓存数据:

a6c0b8c261692deb90f725a35a46493d.png

测试查询缓存数据:

fe490074b9ac16713e861d2e589c06cb.png

测试更新缓存数据:

fc7c8fb12205f0f8dd9df9749561b83c.png

测试删除缓存数据:

f3578503e7d6a82c776edc8d21d6c8c6.png

在Swagger UI界面中:

8a92d1e05191309fc411b2683c7408ab.png

点击testInsert:

dca874423a953c03239aa0540c31e7fd.png

查看控制台的SQL语句:

1eaedc320093c41631ae1bf83c430550.png

: ==> Preparing: INSERT INTO hx_sys_interface_config(ID,APP_CODE,`NAME`,APP_NUM,URL,APP_TEST,END_DATE,STATUS,REMARK1,REMARK2) VALUES(?,?,?,?,?,?,?,?,?,?)

2019-11-05 18:20:43.727 DEBUG 21356 --- [nio-8480-exec-8] c.o.c.m.t.S.insertInterfaceConfig : ==> Parameters: 3(String), htest(String), 接口:4(String), 004(String), www.baidu.com(String), www.baidu.com?i=4(String), 2019-11-05 18:20:43.679(Timestamp), 1(String), remark1(String), remark2(String)

2019-11-05 18:20:43.770 DEBUG 21356 --- [nio-8480-exec-8] c.o.c.m.t.S.insertInterfaceConfig : <== Updates: 1

Swagger界面点击testSelect:

15f287ceb268f7b6a39c9b8e3ba00ae6.png

控制台SQL打印:

2019-11-05 18:23:20.311 DEBUG 21356 --- [nio-8480-exec-7] c.o.c.m.t.S.findInterfaceConfig : ==> Preparing: SELECT * FROM hx_sys_interface_config WHERE ID=?

2019-11-05 18:23:20.312 DEBUG 21356 --- [nio-8480-exec-7] c.o.c.m.t.S.findInterfaceConfig : ==> Parameters: 3(String)

2019-11-05 18:23:20.338 DEBUG 21356 --- [nio-8480-exec-7] c.o.c.m.t.S.findInterfaceConfig : <== Total: 1

id:3,name:接口:4,appNum:004,endDate:2019-11-05 18:20:44

再在Swagger界面点击testSelect:

624ae84175afe64df9132ab39cd2526d.png

可以看到控制台没有打印SQL,没有查询数据库,说明走了缓存,从缓存中取数据:

4c125269772738db8f274380e779f20b.png

查看界面结果,从缓存中取数据:

ef2161f44fe0b4606b8195e3327d38eb.png

在Swagger界面点击testUpdate,更新缓存:

bdb232b5008c9b4e7a5d0b6e3176f1cf.png

控制台更新了数据:

c79f7b575581164dc8a4e180af2cb5ce.png

: ==> Preparing: UPDATE hx_sys_interface_config SET APP_CODE=?,`NAME`=?,APP_NUM=?,URL=?,APP_TEST=?, END_DATE=?,STATUS=?,REMARK1=?,REMARK2=? WHERE ID=?

2019-11-05 18:27:49.148 DEBUG 21356 --- [nio-8480-exec-6] c.o.c.m.t.S.updateInterfaceConfig : ==> Parameters: htest(String), 更新后接口(String), 更新后编号(String), www.baidu.com(String), www.baidu.com?i=4(String), 2019-11-05 18:27:49.096(Timestamp), 1(String), remark1(String), remark2(String), 3(String)

2019-11-05 18:27:49.191 DEBUG 21356 --- [nio-8480-exec-6] c.o.c.m.t.S.updateInterfaceConfig : <== Updates: 1

在Swagger UI点击testSelect:

153d418dc78240a300cd72c3e1663bab.png

查询,控制台没有打印SQL语句,查询成功,从缓存中取出数据,成功

这篇文档简单的说明了Spring Boot集成EhCache的使用方法,后续还会更新。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值