- del key 用于在key存在时删除key
- dump 序列化得定key,并返回被序列化的值
- exists 检查给定key 是否存在
- expire key seconds 为给定key设置过期时间(以秒计时)
- ttl key 以秒为单位,返回给定key的剩余生存时间
- keys pattern 查找所有给定模式的key
keys 通配符 * 代表所有 ? 表示一个字符
- type key 查看所存储key的数据类型
String 类型
- set key 设置给定key的值。如果key已经存储值 set就覆盖旧值,且
- 无视类型
- get key 用于获取指定key值。如果key不存在 返回nil。如果key 储存的值不是字符串类型 返回一个错误。
- seten key 如果key的值不存在时 ,给他赋值。
- incr key 自增
- decr key 自减
- incrby key 增量值
hash类型
- hset key 属性 值 为key设置值
- gset key 属性 根据key 及属性取值
缓存穿透
缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时需要从数据库查询,查询不到数据则不写入数据,这将导致这个不存在的数据每次请求都要到数据库去查询,造成缓存穿透。
解决方法:
持久层查询不到就缓存空结果 查询时先判断缓存中是否exists(key) 如果有直接返回空 没有则查询后返回。
缓存雪崩
如果缓存集中在一段时间内生效 发生大量的缓存穿透,所有的查询都落在数据库上,造成了缓存雪崩。
这个没有完美的解决办法,但是可以分析用户行为 尽量让生效时间点均匀分布。大多数设计者考虑用加锁或者队列的方式保证缓存的单线程写,从而避免失效时大量的并发请求落到底层存储系统是上。