如何在高并发下,http请求返回绝对的当前请求是第几个请求?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何在高并发下,http请求返回绝对的当前请求是第几个请求?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1842字,纯文字阅读大概需要3分钟。
内容图文
![如何在高并发下,http请求返回绝对的当前请求是第几个请求?](/upload/InfoBanner/zyjiaocheng/153/fe299fa3f8664dfbb86628503cb62df0.jpg)
{"n": 1}
我第100次访问请求返回json:{"n": 100}
传统的写数据库,再查数据库返回,在并发大时好像不能保证,我应该怎么办?这应该是最简化了的问题了
回复内容:
比如,我第一次访问请求返回json:{"n": 1}
我第100次访问请求返回json:{"n": 100}
传统的写数据库,再查数据库返回,在并发大时好像不能保证,我应该怎么办?这应该是最简化了的问题了
最简单的方法就是建个自增id主键的mysql表,然后每来一次请求就插一条记录,再读出这条记录,读出的id就是你要的值。
然后就可以根据id值来轻松处理高并发的场景了,比如【秒杀】就可用id小于300且能被6整除的规则认为秒杀成功;【抽奖】可以用能被100整除(百分之一概率)作为中奖等等。
如果自己实现也无非就是单线程死循环处理socket请求维护一个全局变量,不如用现成的mysql方便可靠。
如果是java
的话,一个全局的AtomicLong
可以满足你的需求吧,getAndIncrement
原子操作,再加上volatile
修饰,如果是其他语言,大同小异吧
使用redis中的setnx(id),单线程保证每次加1,而且还是内存数据库,速度超级快。
读操作:使用缓存
写操作:使用队列异步写入
纯粹Java的话,可以把计数器对象做成单例,通过filter
拦截所有请求计算器加1(需要同步)。不知道你说的数据库是什么意思,{n : 100}
,n
是数据库拿的?
其实你要做的是一个常驻内存的队列,按请求先后做排队处理.
单机上可以试试Linux内存文件系统(tmpfs)上/dev/shm读写SQLite.
读文件不需要经过网络,也不需要自己实现内存常驻,锁,自增以及唯一约束.
exec($ddl); // pdo_sqlite 的 query 和 prepare 不支持一次执行多条SQL语句
} else {
$db = new PDO('sqlite:'.$file);
}
$stmt = $db->prepare('INSERT INTO queue(user_id) VALUES(?)');
$stmt->execute(array(time())); //time()换成你的用户ID
echo $stmt->rowCount()."\n"; //查询中受影响(改动)的行数,插入失败时为0
echo $db->lastInsertId(); //插入的自增ID,插入失败时为0
// php -S 127.0.0.1:8080 -t /home/eechen/www >/dev/null 2>&1 &
// ab -c100 -n1000 http://127.0.0.1:8080/
最简单的是用redis的zset进行自增,效率高,简单,单机的话也可以考虑使用atomiclong(宕机重启后失效)
内容总结
以上是互联网集市为您收集整理的如何在高并发下,http请求返回绝对的当前请求是第几个请求?全部内容,希望文章能够帮你解决如何在高并发下,http请求返回绝对的当前请求是第几个请求?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。