EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。
ehcache提供了多种缓存策略,主要分为内存和磁盘两级,所以无需担心容量问题。
spring-boot是一个快速的集成框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。
用户登录之后,几乎之后展示任何页面都需要显示一下用户信息。可以在用户登录成功之后将用户信息进行缓存,之后直接取缓存数据即可。
写在前面
对于SpringBoot而言,内置了属于自己的缓存框架,即:
1
2
3
4
|
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
|
如何使用该框架进行缓存,网上一大堆资料。但是绝大多数都是描述如何在service层进行缓存,之后从数据库取数据的时候直接拿缓存数据,不再进行二次查询了。 但是我目前的需求仅仅是缓存登录用户,下次直接用代码取出来。而不是再调一次service方法!貌似搜到任何资料!可能大家都没遇到过吧。
探索方案
在之前的项目中,曾经用到过EHcache,当然也有对应的EHCacheUtils方法。下面就说一下springboot和ehcache的整合。
真实操作之后,发现整合ehcache非常简单,三步即可:
导入maven包
1
2
3
4
5
|
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache</artifactId>
<version> 2.10 . 1 </version>
</dependency>
|
在启动类开启缓存机制
image.png
添加ehcache配置文件,直接在resources下面新建ehcache.xml文件即可。文件配置如下:
1
2
3
4
|
<?xml version= "1.0" encoding= "UTF-8" ?>
<ehcache>
<cache name= "objectCache" maxElementsInMemory= "1000" ></cache>
</ehcache>
|
使用缓存
此时,springboot已经为ehcacheManager生成了一个Bean。我们在自己需要的地方直接注入即可。下面是我的简单utils文件和存数据取数据的地方,仅供参考。有不对的地方,欢迎指正。
util如下,只提供set和get方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
public class EHCacheUtils {
/**
* 设置缓存对象
* @param cacheManager
* @param key
* @param object
*/
public static void setCache(CacheManager cacheManager,String key,Object object){
Cache cache = cacheManager.getCache( "objectCache" );
Element element = new Element(key,object);
cache.put(element);
}
/**
* 从缓存中取出对象
* @param cacheManager
* @param key
* @return
*/
public static Object getCache(CacheManager cacheManager,String key){
Object object = null ;
Cache cache = cacheManager.getCache( "objectCache" );
if (cache.get(key)!= null && !cache.get(key).equals( "" )){
object = cache.get(key).getObjectValue();
}
return object;
}
}
|
存入缓存方法如下:
1
2
3
4
|
@Autowired
private CacheManager cacheManager;
//部分关键代码
EHCacheUtils.setCache(cacheManager, "op" ,searchOP);
|
取出缓存方法如下:
1
2
3
|
@Autowired
private CacheManager cacheManager;
Operator searchOP = (Operator) EHCacheUtils.getCache(cacheManager, "op" );
|
写在最后
个人觉得,springboot提供的基于注解的方式进行缓存更加适合拦截器的方式去处理。对应指定的请求均去走设置了缓存机制的service方法,该sevice会根据实际情况去直接取缓存或者查询数据库。
总结
以上所述是小编给大家介绍的springboot整合EHCache的实践方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://www.jianshu.com/p/05f3ede0b389