首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
数据库
> 详细
使用Redis+MQ+MySql实现商品秒杀
时间:
2018-09-08 14:09:24
阅读:
596
评论:
0
收藏:
0
[点我收藏+]
标签:
实现
去掉
执行sql
使用
提高
请求
消费者
高并发
判断
基本思路是通过Redis高速缓存来代替缓慢的数据库操作,借此提高系统在高并发情况下的数据处理能力。
原系统:
1)秒杀请求进入后台后被发送到消息队列,并返回入队成功;
2)消息队列的消费者依次处理执行SQL处理消息队列中的秒杀请求;
根据测试,SQL函数的执行时间约为30ms,属于慢SQL,在1000次/s,总计50次请求下,系统能够很快的对50万次请求进行入队操作,但是后续消息队列中请求大约需要执行6小时。
修改后:
1)秒杀请求进入后台后,判断Redis中对应秒杀商品的库存,若有库存则发送到消息队列1,返回入队成功,否则,返回秒杀结束;
2)消息队列1使用Redis对请求进行去重处理,去掉重复的请求后发送给消息队列2;
3)消息队列2使用Redis对对应秒杀商品进行减库存操作,之后发送给消息队列3;
4)消息队列3执行原秒杀系统中SQL,对MySql中对应数据表进行操作;
修改后的系统由于消息队列1、2中都是对Redis的操作,所以执行速度非常快,响应非常迅速,等到了消息队列3时,请求数基本上已经等于秒杀的商品数,需要执行的SQL数量少了,速度自然也就快了,不会发生消息队列的拥堵。
使用Redis+MQ+MySql实现商品秒杀
标签:
实现
去掉
执行sql
使用
提高
请求
消费者
高并发
判断
原文地址:http://blog.51cto.com/8321710/2172024
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
数据库进阶
2021-07-29
在 Oracle 数据库中执行 SQL 语句遇到特殊字符的转义方式
2021-07-28
Windows Logstash同步 Sqlserver 到Elasticsearch
2021-07-26
mysql数据库(11):恢复数据
2021-07-26
mysql数据库(9):常用查询的例子
2021-07-26
SQLAlchemy 多对多
2021-07-26
ClickHouse的JDBC连接
2021-07-26
Apache HBase 1.7.1 发布,分布式数据库
2021-07-26
数据库常用架构和同步工作原理
2021-07-26
MySQL数据库设计规范(仅供参考)
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!