一般情况下,redis用在项目中的缓存,或者在项目中使用redis分布式锁(针对服务器集群)
做缓存时,一般用于大量需要查询的数据,把数据存放到缓存中,避免数据库的压力过大。我曾经的写法是
1.先从redis里根据key查询value
2.指定的key对应的value不存在然后去数据库里查询
3.查出来了之后再把数据以同样的key+value+过期时间存到redis里
4.直接根据从数据库里获取的数据进行操作拿到自己想要的数据,然后直接返回
偶然在项目中看到的写法是,
1.先从redis里根据key查询value
2.指定的key对应的value不存在然后去数据库里查询
3.查出来了之后再把数据以同样的key+value+过期时间存到redis里,再存之前先删除一遍key(猜测应该是排除并发的现象,上一个线程在这个保存之前已经保存了一份key,那么根据redis再hmset时因为key唯一,所以,Key不能hmset进去,设置的过期时间不是最新的),然后再hmset(key,value),然后设置过期时间【此处有一些问题,Hmset命令会覆盖已经存在的key+field,所以暂时不确定为什么在setKey的时候还要重新删一遍】
4.从redis里再次根据Key查询数据