PHP结合memcacheq消息队列解决并发问题

原创 2016年08月31日 09:22:12

在处理业务逻辑时有可能遇到高并发问题,例如商城秒杀、微博评论等。如果不做任何措施可能在高瞬间造成服务器瘫痪,如何解决这个问题呢?队列是个不错的选择。队列(Queue)又称先进先出(First In First Out)利用消息队列可以很好地异步处理数据传送和存储,当你向数据库中写入数据就可采取消息队列来异步插入。只要有并发限制的地方基本都可以使用队列来解决。这里先重点介绍一下memcacheq。

    持久化消息队列memcacheq是一个轻量级的消息队列。依附于Berkeley DB和libevent。Berkeley DB用于持久化存储队列的数据,避免在memcacheq出问题时造成数据丧失。接下来看一下安装过程,首先下载libevent-1.4X***、BerkeleyDB5.0、memcacheq-0.2.0,下载地址:

    http://monkey.org/~provos/libevent/

    http://download.oracle.com/berkeley-db/db-5.0.21.tar.gz

    http://code.google.com/p/memcacheq/downloads/list

安装步骤:

    tar zxvf libevent-1.4.14b-stable.tar.gz
cd libevent-1.4.14b-stable
./configure
make
make install
ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2
cd ..
tar zxvf db-5.0.21.tar.gz
 cd db-5.0.21/build_unix/
../dist/configure
make
make install
vi /etc/ld.so.conf
加入以下两行
/usr/local/lib
/usr/local/BerkeleyDB.5.0/lib
执行
ldconfig
cd ../../
 tar zxvf memcacheq-0.2.0.tar.gz
cd memcacheq-0.2.0
./configure --with-bdb=/usr/local/BerkeleyDB.5.0 --with-libevent=/usr/local/lib --enable-threads
make
make install
启动前确定一下 日志目录是否存在  如果不存在需要手动创建
memcacheq -d -r -uroot -p22201 -H /data0/memcacheq -N -v -L 1024 -B 1024 > /data0/mq_error.log 2>&1
  参数说明: 
-d : 以后台服务方式运行 
-l :  设置监听地址及端口(默认端口是22201) 
-A : 数据页大小 
-H : 数据保存目录 一定要存在 
-B : 队列中每条数据的最大长度(字节) 
-N : 使用内存缓冲方式保存数据至磁盘,从而获得极高性能。若无此参数,性能会很差 
-R : 自动清理过期的日志 -u : 设置memcacheq进程账号

    PHP代码示例:

  1. $memcache_obj = new Memcache;
  2. $memcache_obj->connect('192.168.1.106'22201);

  3. $memcache_obj->set('a',time(),0,0);//入栈
  4. echo $memcache_obj->get('a');      //出栈
版权声明:本文为博主原创文章,未经博主允许不得转载。

MemcacheQ 安装与使用

MemcacheQ 是一个基于 MemcacheDB 的消息队列服务器。官网地址:http://memcachedb.org/memcacheq/ 特点: 1.简单易用。 2.处理速度快。 3.可...
  • fdipzone
  • fdipzone
  • 2014年01月07日 00:43
  • 23972

PHP结合memcacheq消息队列解决并发问题

在处理业务逻辑时有可能遇到高并发问题,例如商城秒杀、微博评论等。如果不做任何措施可能在高瞬间造成服务器瘫痪,如何解决这个问题呢?队列是个不错的选择。队列(Queue)又称先进先出(First In F...
  • j393819650
  • j393819650
  • 2017年03月02日 11:31
  • 322

PHP解决抢购、秒杀、抢楼、抽奖等阻塞式高并发库存防控超量的思路方法

如今在电商行业里,秒杀抢购活动已经是商家常用促销手段。但是库存数量有限,而同时下单人数超过了库存量,就会导致商品超卖甚至库存变负数的问题。 又比如:抢购火车票、论坛抢楼、抽奖乃至爆红微博评论等也会引...
  • jimlong
  • jimlong
  • 2015年08月20日 11:12
  • 25715

php高并发秒杀解决方案

在秒杀、抢火车票等地方,我们通常用遇到这样高并发的问题,下面我提供了四种解决方案: 1、使用文件锁 $fp = fopen("order.lock", "r"); if(flock($fp,LOCK_...
  • super_runman
  • super_runman
  • 2016年11月04日 17:20
  • 13784

消息队列在项目中的使用(memcacheq)

什么是消息队列? 消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法。 每个数据块都被认为含有一个类型,接收进程可以独立地接收含有不同类型的数据结构。我们可以通过发送消息来避免命名管道的同...
  • tiedanzi
  • tiedanzi
  • 2016年11月04日 15:47
  • 2660

PHP结合memcacheq消息队列解决并发问题

在处理业务逻辑时有可能遇到高并发问题,例如商城秒杀、微博评论等。如果不做任何措施可能在高瞬间造成服务器瘫痪,如何解决这个问题呢?队列是个不错的选择。队列(Queue)又称先进先出(First In F...
  • g_hongjin
  • g_hongjin
  • 2016年08月31日 09:22
  • 1068

memcacheq-0.2.0.tar.gz

  • 2012年09月28日 15:39
  • 128KB
  • 下载

PHP解决并发问题的几种实现

对于商品抢购等并发场景下,可能会出现超卖的现象,这时就需要解决并发所带来的这些问题了 在PHP语言中并没有原生的提供并发的解决方案,因此就需要借助其他方式来实现并发控制。 方案一:使用文件锁排它锁 f...
  • kankan231
  • kankan231
  • 2016年04月10日 00:24
  • 10092

Memcache 持久化消息队列MemcacheQ

memcacheQ是一个国内开发的基于memcache协议、BDB持久数据存储、高性能轻量级分布式消息队列服务。它的安装依赖于BerkeleyDB 和 libevent,所以要先安装这Berkeley...
  • tianwei7518
  • tianwei7518
  • 2015年04月04日 23:51
  • 4735

memcacheq 服务安装与原理

memcacheQ是一个单纯的分布式消息队列服务。它的安装依赖于BerkeleyDB 和 libevent,所以要先安装这BerkeleyDB和libevent: 一,BerkeleyDB ...
  • 21aspnet
  • 21aspnet
  • 2011年07月19日 18:19
  • 3345
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP结合memcacheq消息队列解决并发问题
举报原因:
原因补充:

(最多只允许输入30个字)