php memcached的高并发处理队列实现有关问题
程序员文章站
2022-04-03 10:13:24
...
php memcached的高并发处理队列实现问题
刚看了memcached处理抢购问题的队列的一些代码,我理解到的思路有两种
1.使用 $mem->set(LOCK_key,1) 来加锁,入队结束后 $mem->delete(LOCK_key) 解锁
2.使用memcached 的 increment(key,1) 来获得队列位置
我的问题是:
1.第一种方法可行吗?
2.$memcached->increment(key,1) 这个函数能处理并发访问吗?也就是多个进程同时调用 increment函数,会不会发生并发覆盖问题?
我今年大四了,在不断找工作中,由于之前学习的不够系统的PHP,被 YY 和 4399 都复试的时候刷了。
心很凉,找工作不易,且行且珍惜,我要好好加油,谢谢各位大牛拉我一把
------解决思路----------------------
会发生冲突
你自己测试一下就知道
------解决思路----------------------
只用memcached你这样会冲突的,对于高并发冲突,可使用memcacheQ来解决。
memcacheq 是专为门为解决高并发问题所开发的中间件,以队列的方式存取数据。
参考:http://blog.csdn.net/fdipzone/article/details/17933673
刚看了memcached处理抢购问题的队列的一些代码,我理解到的思路有两种
1.使用 $mem->set(LOCK_key,1) 来加锁,入队结束后 $mem->delete(LOCK_key) 解锁
2.使用memcached 的 increment(key,1) 来获得队列位置
我的问题是:
1.第一种方法可行吗?
2.$memcached->increment(key,1) 这个函数能处理并发访问吗?也就是多个进程同时调用 increment函数,会不会发生并发覆盖问题?
我今年大四了,在不断找工作中,由于之前学习的不够系统的PHP,被 YY 和 4399 都复试的时候刷了。
心很凉,找工作不易,且行且珍惜,我要好好加油,谢谢各位大牛拉我一把
------解决思路----------------------
会发生冲突
你自己测试一下就知道
------解决思路----------------------
只用memcached你这样会冲突的,对于高并发冲突,可使用memcacheQ来解决。
memcacheq 是专为门为解决高并发问题所开发的中间件,以队列的方式存取数据。
参考:http://blog.csdn.net/fdipzone/article/details/17933673
相关文章
相关视频
上一篇: PHP求解最长公共子串的方法
下一篇: php7什么时候发布的