秒杀系统架构关键技术-流量削峰

排队
要对流量进行削峰,最容易想到的解决方案就是用消息队列来缓冲瞬时流量,把 同步的直接调用转换成异步的间接推送,中间通过一个队列在一端承接瞬时的流 量洪峰,在另一端平滑地将消息推送出去。在这里,消息队列就像“水库”一 样, 拦蓄上游的洪水,削减进入下游河道的洪峰流量,从而达到减免洪水灾害 的目的。但是,如果流量峰值持续一段时间达到了消息队列的处理上限,例如本机的消息 积压达到了存储空间的上限, 消息队列同样也会被压垮,这样虽然保护了下游的 系统 ,但是和直接把请求丢弃也没多大的区别。就像遇到洪水爆发时,即使是有水库恐怕也无济于事。
除了消息队列,类似的排队方式还有很多,例如:
1. 利用线程池加锁等待也是一种常用的排队方式;
2. 先进先出、先进后出等常用的内存排队算法的实现方式;
3. 把请求序列化到文件中,然后再顺序地读文件(例如基于 MySQL binlog 的同步机制)来恢复请求等方式。
答题
第一个目的是防止部分买家使用秒杀器在参加秒杀时作弊。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值