秒杀场景
1.购物车存储问题(登录才能使用购物车/登不登录都能使用购物车)
登录:存入redis(hash)/mysql
未登录:cookie (4k) localstorage(5M) webSql
2.超卖问题
innodb的行级锁技术 使用sql语句进行更新数据加入条件数量>0 不要把库存封装到对象再更新
3.提交订单时要去数据库查询最新价格计算总价不能以购物车价格为准
4.微信支付流程
5.秒杀
6.常见问题解决方案
秒杀里的重复排队问题
int count = this.redisTemplate.boundsHashOps("UserQueueCount").increment(username, 1);
if (count > 1){
throw new RuntimeException("重复排队");
}
秒杀里的并发削峰操作
秒杀微服务立即下单 而是把订单排队到redis队列里, 然后多线程抢单(检查账号异常,抢单要求)等问题
也可以让用户输入验证码实现削峰
超卖问题
把每个库存提前存入redis队列
// 给每个商品添加一个计数器
this.redisTemplate.boundHashOps("SeckillGoodsCount").increment(goodsId, goodsCount);
// 商品个数队列创建 pushIds是数组 集合会认为是一个对象
this.redisTemplate.boundListOps("SeckillGoodsCountList_" + seckillGood.getId()).leftPushAll(pushIds);
// 从队列里拿数据 有数据则有库存 无数据无库存
Object goodList = this.redisTemplate.boundListOps("SeckillGoodsCountList_" + goodsId).rightPop();
超时订单回滚问题
rockerMq监听 超时未支付回滚