前言
在 shiro 中每次去拦截请求进行权限认证的时候,都会去数据库查询该用户的所有权限信息, 这个时候就是有一个问题了,因为用户的权限信息在短时间内是不可变的,每次查询出来的数据其实都是重复数据,没必要每次都去重新获取这个数据,统一放在缓存中进行管理,这个时候,我们只需要获取一次权限信息,存入到缓存中,待缓存过期后,再次重新获取即可。
例如,我执行一个查询多次,它执行多次权限查询。
使用 Reids 缓存
加入 shiro-redis 依赖
1 | <!-- shiro-redis --> |
配置 Redis
和前面系统配置 Reids 一样。
在系统配置文件中加入 Redis 配置参数:
1
2
3
4
5
6
7
8
9
10
11
12spring:
redis:
host: 192.168.19.200 # host ,默认 localhost
port: 6379 # 端口号,默认6379
pool:
# 设置都是默认值,可以按需求设计
max-active: 8 # 可用连接实例的最大数目,默认值为8;如果赋值为-1,则表示不限制;
max-idle: 8 # 控制一个pool最多有多少个状态为idle(空闲的)的redis实例,默认值也是8。
max-wait: -1 # 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。
min-idle: 0 # 控制一个pool最少有多少个状态为idle(空闲的)的redis实例,默认值为0。
timeout: 0 # 连接超时时间 单位 ms,默认为0
password: master # 密码,根据自己的 redis 设计,默认为空这个我们是要使用 RedisManager 管理我们的 Redis,它默认没有注入我们设置的这些参数,需要我们自己手动创建一个注入我们设置的参数。
1
2
3
4"spring.redis") (prefix =
public class CustomRedisManager extends RedisManager {
}
配置 Shiro 缓存
1 | /** |
使用测试
我们加入缓存后,看是个什么情况:
执行多次请求,只执行了一次查询权限的 SQL。
可以去 redis-cli 查看 keys,检查是否存在权限对象的 key。
使用 Ehcache 缓存
加入依赖
1 | <!-- shiro ehcache --> |
Ehcache 配置
新增一个 Ehcache 配置文件 shiro-ehcache.xml
:
1 | <?xml version="1.0" encoding="UTF-8"?> |
配置 EhCache 缓存
1 | /** |