首先本次请求有一个traceId,也就是请求的唯一标识(原则上永远不会重复)
以此traceId或与此traceId相关的字符串作为key,value可任意
使用redis塞缓存(redis不是分布式的,所以以非分布式的缓存来解决分布式服务的一致性问题)
设置缓存注意两个点:
- setnx 这是redis设置缓存的指令,当设置成功时返回1,失败返回0。(当前key已存在则为失败,不存在则为成功,这是setnx的特性)
- 设置过期时间 防重点是在很快的点击时,才会“防”,所以过期时间不需要太长,这样也可以减轻redis压力。此处建议设置50ms