redis穿透:正常的执行路径是这样的,请求数据,首先会从redis缓存中拿数据,如果缓存没有的话才去查数据库,再写到redis缓存中。那么如果有人请求一条根本不存在的数据时,redis里面肯定没有嘛,它就会去访问数据库,但是数据库没有,所以它也没把数据写回redis缓存。所以它每次请求这个数据的时候它就会直接去访问数据库。如果请求的数量太大的话,都直接穿过redis直接去访问数据库,数据库承受不了这个访问数量。
解决办法:在redis里面用一个set集来把数据库查询的那个查询主键都读出来存到这个set集里面。如果有请求时,先查redis里面的set有没有这个主键,如果没有就直接返回,不查数据库。如果有的话查redis,如果没有的话才去查数据库并把数据库里的数据写到缓存中。
判断元素是否在集合中,无论集合中有多少元素都可以极速的返回结果。
SISMEMBER key member
127.0.0.1:6379> sismember set a
(integer) 1
127.0.0.1:6379> sismember set h
(integer) 0