记一次由于缓存导致的bug

bug描述

有一张数据库表存储的是 值日员工信息,有时候可能一次性录入1个月的数据、有时候也可能隔了很多天没有录入数据,也就是说这个录数据不是很规律。

bug现象:测试人员发现,网站上三亚地区能正常显示当天值日员工信息,但是珠海地区却不能正确显示当天值日员工信息。而数据库上实际是有珠海地区值日员工信息的。更诡异的是在本地启动网站的时候珠海和三亚地区当天值日员工信息都能正常显示。

原因是因为,代码里面用了缓存,这个缓存持续时间6小时。三亚地区人员信息是早上9点录入的,珠海是下午3点录入的。当有人查看值日信息的时候,时间恰好在9点到3点之间,这样三亚的缓存里面存了数据,而珠海的缓存里面就存了0条数据。完美的解决方法就是不用缓存,每次都去查数据库,这样做的缺点是性能有影响。恰当的做法就是,判断缓存是否存在并且缓存条数是不是为0,如果缓存不存在肯定要去读数据库,并将读到的数据存入缓存中。如果读到缓存条数为0,也要去读一下数据库,将读的结果存入缓存(当然这个有可能出现不准,但是符合我们的环境)。

猜你喜欢

转载自www.cnblogs.com/wholeworld/p/10226823.html