javaweb电商抢购秒杀实现思路

Lindp 2015-08-26 06:25:35
大家好,最近领导下来任务让做一个现在电商很普遍的抢购秒杀这类的功能,小弟之前一直在web浅水区晃悠,突然来这么个高端业务搞得我一点头绪都没有

我的思路:今天在网上查了些资料,大概是:我卖100个商品,当前有1000个请求,我利用filter操作redis记录当前的请求数是否达到100,如果达到之后所有请求到活动结束页面,剩下的请求使用锁来控制一个个的处理

问题:
1.这种方式其实服务器已经在filter处理了所有的请求,有没有方式可以在客户端就将部分用户请求筛选出去?如果没有那filter记录当前抢购已满是否有必要控制页面上抢购按钮置灰?
2.比较担心锁相关的问题,使用锁势必导致用户体验非常差,是否有更好的方式?

谢谢
...全文
12796 点赞 收藏 9
写回复
9 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
引用 3 楼 EthanLindp 的回复:
你好,这个视频我看过,主要是说如何在前端制作限时抢购计时功能 队列方面我最近也在看相关的资料,但是我比较疑惑的是如何将请求放入队列中,然后逐一处理?
look look
回复
迷林 2015-08-27
引用 2 楼 shijing266 的回复:
我个人的观点,用队列吧,服务端从队列取,取满就提示抢购完毕
你这么能回答问题 你爸妈知道吗??
回复
Lindp 2015-08-27
引用 2 楼 shijing266 的回复:
我个人的观点,用队列吧,服务端从队列取,取满就提示抢购完毕
你好,这个视频我看过,主要是说如何在前端制作限时抢购计时功能 队列方面我最近也在看相关的资料,但是我比较疑惑的是如何将请求放入队列中,然后逐一处理?
回复
猫神jdx 2015-08-27
引用 7 楼 u012459865 的回复:
@Override public void pushTask(String task,String value) { redisService.getJedisTemplate().opsForList().leftPush(task, value); } @Override public Object popTask(String task) { Object s = redisService.getJedisTemplate().opsForList().rightPop(task); return s; } 参考下,redis队列,左插入,右弹出,
写错了,是redisTemplate.opsForList().XXXXX
回复
引用 6 楼 EthanLindp 的回复:
我不是问这个,队列的操作应该基本没什么问题,我是想问下如何能做到让所有的请求进入队列,然后如何处理队列中的数据呢?
为啥要所有请求进入呢? 进入一个取一个,取满为止,队列的存在是保证让后面的等待,避免并发
回复
猫神jdx 2015-08-27
@Override public void pushTask(String task,String value) { redisService.getJedisTemplate().opsForList().leftPush(task, value); } @Override public Object popTask(String task) { Object s = redisService.getJedisTemplate().opsForList().rightPop(task); return s; } 参考下,redis队列,左插入,右弹出,
回复
Lindp 2015-08-27
引用 5 楼 shijing266 的回复:
[quote=引用 3 楼 EthanLindp 的回复:] 你好,这个视频我看过,主要是说如何在前端制作限时抢购计时功能 队列方面我最近也在看相关的资料,但是我比较疑惑的是如何将请求放入队列中,然后逐一处理?
look look[/quote] 我不是问这个,队列的操作应该基本没什么问题,我是想问下如何能做到让所有的请求进入队列,然后如何处理队列中的数据呢?
回复
我个人的观点,用队列吧,服务端从队列取,取满就提示抢购完毕
回复
相关推荐
发帖
Web 开发
创建于2007-09-28

8.0w+

社区成员

Java Web 开发
申请成为版主
帖子事件
创建了帖子
2015-08-26 06:25
社区公告
暂无公告