1 缓存框架EhCache使用
缓存可以提高查询数据性能, 对同一批数据进行多次查询时, 第一次查询走数据库,查询数据后,将数据保存在内存中,第二次以后查询 可以直接从内存获取数据,而不需要和数据库进行交互。
控制台打印数据分析
每次访问一个需要被权限控制资源时,调用Realm的授权方法,根据当前用户查询角色(role)和权限(permission)信息,每次调用 都会查询一次数据库
问题: 为什么使用ehcache而不使用redis缓存
1、Shiro 默认对ehcache的支持
2、在后台管理系统中 ehcache使用非常普遍 ,因为spring可以集成ehcache。
3、ehcache不需要单独启动服务器,而redis需要启动单独的服务器
4、ehcache称为本地缓存,redis称为服务器缓存
1.1.1 Ehcache是什么
EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点.
主要的特性有:
-
快速
-
简单
-
多种缓存策略
-
缓存数据有两级:内存和磁盘,因此无需担心容量问题
-
缓存数据会在虚拟机重启的过程中写入磁盘
-
可以通过RMI、可插入API等方式进行分布式缓存
-
具有缓存和缓存管理器的侦听接口
-
支持多缓存管理器实例,以及一个实例的多个缓存区域
1.1.2 Spring和EhCache 框架整合
第一步: 在common_parent 导入 ehcache maven坐标
导入Ehcache 开发包
<!-- 导入eheache的缓存包 -->
<dependency>
<groupId>net.sf.ehcache</groupId>