Redis的两种写
CPU 内存 磁盘这三种访问的速度是由快到慢的,它们之间的容量是从小到大的,因此就有了只读缓存和读写缓存两种模式。
第一种是写在数据库中,然后缓存未命中则去查数据库,查到了之后再写入缓存。
第二种是同时写Redis和数据库,但是就有了同步写和异步写。
同步写要缓存和数据库同时写完。
异步写只需要写好缓存,缓存满了之后,写进数据库就可以了。
缓存雪崩,击穿,穿透
缓存雪崩
大量缓存同一时刻过期,查询全到数据库,导致数据库层的压力激增,可以设置过期值不同。
缓存击穿
热点key过期后,查询全到数据库,设置热点key不过期。
缓存穿透
缓存和数据库都不存在这个数据,可以返回null值回缓存,或者用布隆过滤器。
所有三种方法都可以用熔断,限流。
LRU和LFU
LRU
删除掉最早访问的数据,但是有一个缺点,如果数据是每一个都进行查询的话,也是会这些数据造成污染的。
LFU
从最早访问和访问次数两方面对LRU进行了优化。
Redis并发
在并发领域,如果需要把一些命令同时执行,那么就需要使用lua命令,它可以保证Redis执行命令的原子性。