问一个关于时间控制的典型问题

helloha2013 2012-07-26 01:17:29
业务关于一个抢先发言的问题,假设有1000个用户,5秒钟内抢先发言,且只能有一个人发言;5秒后谁也不能发言
由于客户要求,不能使用session

我是这样处理的
数据库中建立一个发言表tableWords,如果有第一个用户要抢先发言则,添加一条记录,之后其他的用户在抢发言,如果表中有记录,则不让发言;

这样做似乎没有问题,但考虑到并发的情况,很有可能1000个用户中有多个人在同一毫秒都执行了insert 操作,,如何只让一个用户insert了?
...全文
90 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
helloha2013 2012-07-26
  • 打赏
  • 举报
回复
显然这样我就该给分了。
amani11 2012-07-26
  • 打赏
  • 举报
回复
事务 文件锁 信号量锁等,用来判断用户发言资格


还可以依靠数据库唯一索引,字段可以由话题id?等指定,总之要唯一,显然这样就符合你的需求了
helloha2013 2012-07-26
  • 打赏
  • 举报
回复
你说的我知道,我说的详细点:

考虑最简单的情况,数据库中没有记录。

判断的伪代码如下:
$count=mysqlq("select count(id) from tableWords ");
if($count<1) {
//假设开始抢的过程中,有10个用户都进入了这个条件分支,尽管有排队,不就都insert 了吗?

insert into tableWords()values(...);
}
xuzuning 2012-07-26
  • 打赏
  • 举报
回复
你的这个担忧是多余的
哪怕是同一微秒这1000个用户都发出了请求,在第一时刻也只有一个用户的请求被响应,其他的只是在排队

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧