一次Spring Cache使用不当带来的生产环境问题

问题描述

用户登录系统提示没有权限,导致用户无法使用系统

原因分析:

用户登录的方法A会调用第三方接口获取用户信息,没有对数据进行校验导致。
第三方接口的正确返回的数据格式:

 "status":200,
 "data":[{“username”:"user007"}]
}

导致bug的数据格式:

 "status":200,
 "data":[]
}

因为登录方法A使用Cacheable 注解,没有校验data里面的username是否为空就直接放入了redis缓存,所以导致用户在一个小时内都无法使用系统。

解决方案:

因为每次发版都有严格的审批流程,所以,只能先在预发布环境暂时处理,毕竟预发布环境和生产环境使用同一个数据库,等下个版本再完成bugfix功能。

  1. 预发布环境处理:写个删除Redis缓存功能,哪个用户有问题就删除哪个用户的缓存。
  2. 生产环境处理:拿到第三方的接口数据之后,对data进行判断,如果是空就重新请求3次,没有数据就不存入Redis缓存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值