SpringBoot中如何使用EhCache

发布时间:2021-07-24 14:40:02 作者:Leah
来源:亿速云 阅读:125

这篇文章给大家介绍SpringBoot中如何使用EhCache,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

一、EhCache使用演示

EhCache是一个纯Java的进程内缓存框架,具有快速、精干等特点,Hibernate中的默认Cache就是使用的EhCache。

本章节示例是在Spring Boot集成Spring Cache的源码基础上进行改造。源码地址:https://github.com/imyanger/springboot-project/tree/master/p20-springboot-cache

使用EhCache作为缓存,我们先引入相关依赖。

<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-web</artifactId></dependency><!--ehcache依赖--><dependency>  <groupId>net.sf.ehcache</groupId>  <artifactId>ehcache</artifactId></dependency><dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-cache</artifactId></dependency>

然后创建EhCache的配置文件ehcache.xml。

<?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">  <!--    磁盘存储:将缓存中暂时不使用的对象,转移到硬盘,类似于Windows系统的虚拟内存    path:指定在硬盘上存储对象的路径    path可以配置的目录有:    user.home(用户的家目录)    user.dir(用户当前的工作目录)    java.io.tmpdir(默认的临时目录)    ehcache.disk.store.dir(ehcache的配置目录)    绝对路径(如:d:\\ehcache)    查看路径方法:String tmpDir = System.getProperty("java.io.tmpdir");   -->  <diskStore path="java.io.tmpdir" />  <!--    defaultCache:默认的缓存配置信息,如果不加特殊说明,则所有对象按照此配置项处理    maxElementsInMemory:设置了缓存的上限,最多存储多少个记录对象    eternal:代表对象是否永不过期 (指定true则下面两项配置需为0无限期)    timeToIdleSeconds:最大的发呆时间 /秒    timeToLiveSeconds:最大的存活时间 /秒    overflowToDisk:是否允许对象被写入到磁盘    说明:下列配置自缓存建立起600秒(10分钟)有效 。    在有效的600秒(10分钟)内,如果连续120秒(2分钟)未访问缓存,则缓存失效。    就算有访问,也只会存活600秒。   -->  <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="600"         timeToLiveSeconds="600" overflowToDisk="true" />  <cache name="cache" maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120"      timeToLiveSeconds="600" overflowToDisk="true" /></ehcache>

然后SpringBoot配置文件中,指明缓存类型并声明Ehcache配置文件的位置。

server: port: 10900spring: profiles:  active: dev cache:  type: ehcache  ehcache:   config: classpath:/ehcache.xml

这样就可以开始使用Ehcache了,测试代码与Spring Boot集成Spring Cache一致。

SpringBoot启动类,@EnableCaching开启Spring Cache缓存功能。

@EnableCaching@SpringBootApplicationpublic class SpringbootApplication {  public static void main(String[] args) {    String tmpDir = System.getProperty("java.io.tmpdir");    System.out.println("临时路径:" + tmpDir);    SpringApplication.run(SpringbootApplication.class, args);  }}

CacheApi接口调用类,方便调用进行测试。

@RestController@RequestMapping("cache")public class CacheApi {  @Autowired  private CacheService cacheService;  @GetMapping("get")  public User get(@RequestParam int id){    return cacheService.get(id);  }  @PostMapping("set")  public User set(@RequestParam int id, @RequestParam String code, @RequestParam String name){    User u = new User(code, name);    return cacheService.set(id, u);  }  @DeleteMapping("del")  public void del(@RequestParam int id){    cacheService.del(id);  }  }

CacheService缓存业务处理类,添加缓存,更新缓存和删除。

@Slf4j@Servicepublic class CacheService {  private Map<Integer, User> dataMap = new HashMap <Integer, User>(){    {      for (int i = 1; i < 100 ; i++) {        User u = new User("code" + i, "name" + i);        put(i, u);      }    }   };  // 获取数据  @Cacheable(value = "cache", key = "'user:' + #id")  public User get(int id){    log.info("通过id{}查询获取", id);    return dataMap.get(id);  }  // 更新数据  @CachePut(value = "cache", key = "'user:' + #id")  public User set(int id, User u){    log.info("更新id{}数据", id);    dataMap.put(id, u);    return u;   }  //删除数据  @CacheEvict(value = "cache", key = "'user:' + #id")  public void del(int id){    log.info("删除id{}数据", id);    dataMap.remove(id);  }  }

关于SpringBoot中如何使用EhCache就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. Spring Boot如何使用EhCache演示
  2. 怎么在SpringBoot中使用Redis和Ehcache缓存Shiro

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

springboot ehcache

上一篇:js中遍历的示例分析

下一篇:java字符串遍历以及统计字符串中各类字符的示例分析

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》