redis 缓存 golang
一:缓存穿透1:概念举个栗子,当用户查询一个数据,首先查redis内存数据库发现没有,即缓存没命中。于是向持久层数据库(mongo,mysql等)查询,发现也没有,于是本次查询失败。当用户很多的时候,缓存都没有命中,于是都去请求了持久层数据库。这会给持久层数据库造成很大的压力,这就是缓存穿透。2:解决方案缓存空对象:当持久层数据库不命中后,即使返回的空对象也将其缓存起来,同时设置过期时间,之后再访问这个数据将会从缓存层中获取,不再访问持久层数据库,减少了数据库压力。不过这个有个场景会适得其反,假如