文章目录
- 秒杀写库策略
- 确保缓存的订单数据不丢失
秒杀写库策略
- 在我们的抽奖函数中,抽中奖品、减库存成功返回给前端后就应该生成订单写入数据库
- 但是这里有问题,我们的抽奖函数是支持高并发的,并发量大的情况下mysql无法支持这么大并发量的写入
- 优化思路是先把订单信息放入channel里面,然后单独开一个协程专门从channel里面读出订单信息写入mysql
确保缓存的订单数据不丢失
- 不能很武断地停掉我们的go进程,必须等所有数据都持久化到数据库之后才能允许关闭go进程
- 只有当main中读channel写入mysql这个协程结束任务后才能允许退出
- 当要close channel时要切记不能重复关闭channel
- 思路,再开辟一个stop channel,写入mysql完成后发送信号,里面有信号则由单一协程负责关闭order channel,然后take order函数结束,writeOrderFinish这个标志被设置为true
- kill 是向某个协程发送2、9、15等信号,9 无条件选择终止,2和15软信号
- signal.Notify当收到指定信号会往channel里面写入
- 只有writeOrderFinish==true才可以exit(0)