1、背景:
在实际的开发中,很多的接口一放到生产环境,由于数据量大,请求量大等等原因,有些接口从请求到数据返回耗时很长,非常影响用户的体验(接口一般要保证在1s内返回) 。
2、解决方法思路:
(1)首先想到的当然是优化接口,提高接口性能。
(2)但是,当接口优化还解决不了问题时,那么就要考虑第二种方法了,立马想到了缓存,首先想到的是redis,又考虑到redis是内存缓存,如果redis出问题时,会丢失数据(没设置落盘),所有就想,再加一层mysql缓存。于是,思路如下:
a.编写定时任务,定时执行提前算好结果集,定义一个唯一的值来md5或者base64编码生成redis的key(可以用接口的入参、url、方法类型:post/get来唯一确定key),然后存储到redis,接着在存到mysql,如果有就更新,没有就添加.
b.当请求某接口时,先获取参数来生成key,用key在redis获取值,如果获取到,直接返回,这样的速度就非常快。
c.当连接redis失败或者从redis获取key对应的data失败时,就查询mysql读取缓存,如果有就返回,这样的返回速度也是很快的。
d.如果mysql还没获取到(理论上定时任务是提前进行的,基本不可能出现这个情况,如果出现了,就只能重新计算了),那就触发定时任务的计算函数,重复步骤a来添加缓存,并返回数据。