持久化消息队列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
启动前确定一下日志目录是否存在 如果不存在需要手动创建
创建目录
mkdir -p 755 var/memcacheq/logs/
mkdir -p 755 var/memcacheq/data/
开启memcacheq
/usr/local/bin/memcacheq -d -r -uroot -p22201 -H var/memcacheq/data -N -R -v -L 1024 -B 1024 > var/memcacheq/logs/mq_error.log 2>&1
PHP代码示例:
- <?php
- /* 连接memcacheq server */
- $memcache_obj = new Memcache();
- $memcache_obj->connect('localhost', 22201); // default port 22201
- /* 添加到对列 */
- $memcache_obj->set('demoqueue1', 'message body here1', MEMCACHE_COMPRESSED, 0);
- $memcache_obj->set('demoqueue1', 'message body here2', MEMCACHE_COMPRESSED, 0);
- $memcache_obj->set('demoqueue1', 'message body here3', MEMCACHE_COMPRESSED, 0);
- $memcache_obj->set('demoqueue1', 'message body here4', MEMCACHE_COMPRESSED, 0);
- /* 移出对列 */
- echo $memcache_obj->get('demoqueue1').'<br>';
- echo $memcache_obj->get('demoqueue1').'<br>';
- echo $memcache_obj->get('demoqueue1').'<br>';
- echo $memcache_obj->get('demoqueue1').'<br>';
- $memcache_obj->close();
- ?>
memcacheq -h 查看更多设置
参数说明:
-d : 以后台服务方式运行
-l : 设置监听地址及端口(默认端口是22201)
-A : 数据页大小
-H : 数据保存目录一定要存在
-B : 队列中每条数据的最大长度(字节)
-N : 使用内存缓冲方式保存数据至磁盘,从而获得极高性能。若无此参数,性能会很差
-R : 自动清理过期的日志 -u : 设置memcacheq进程账号