1、安装libevent

官网:http://www.libevent.org/

全选复制放进笔记
$ wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz --no-check-certificate
$ tar -zxvf libevent-2.0.21-stable.tar.gz
$ cd libevent-2.0.21-stable
$ ./configure --prefix=/usr/local/libevent
$ sudo make && make install

2、安装 BerkeleyDB

官网:http://www.oracle.com/technetwork/products/berkeleydb/downloads/index.html(下载需要登录)

安装:

全选复制放进笔记
$ wget http://download.oracle.com/berkeley-db/db-6.0.30.tar.gz
$ tar -zxvf db-6.0.30.tar.gz (根据自身的情况解压到目录)
$ cd db-6.0.30/build_unix
$ ../dist/configure --prefix=/usr/local/berkeleyDB
$ sudo make && make install

安装完成之后:

全选复制放进笔记
$ export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/libevent/lib:/usr/local/berkeleyDB/lib

或者:

全选复制放进笔记
$ vim /etc/ld.so.conf

添加:

全选复制放进笔记
/usr/local/libevent/lib
/usr/local/berkeleyDB/lib

并执行:

全选复制放进笔记
$ /sbin/ldconfig

3、安装 MemcacheQ

官网:http://memcachedb.org/memcacheq/

全选复制放进笔记
$ wget https://memcacheq.googlecode.com/files/memcacheq-0.2.0.tar.gz
$ tar -zxvf memcacheq-0.2.0.tar.gz
$ cd memcacheq-0.2.0
$ ./configure --prefix=/usr/local/memcacheq --enable-threads --with-libevent=/usr/local/libevent --with-bdb=/usr/local/berkeleyDB
$ sudo make && make install

测试是否安装成功:

全选复制放进笔记
/usr/local/memcacheq/bin/memcacheq -h

4、启动服务

建立相关目录:

全选复制放进笔记
mkdir -p 755 /var/memcacheq/logs/
mkdir -p 755 /var/memcacheq/data/

启动服务:

全选复制放进笔记
/usr/local/memcacheq/bin/memcacheq -d -r -uroot -p11212 -H /var/memcacheq/data -N -R -v -L 1024 -B 1024 > /var/memcacheq/logs/mq_error.log 2>&1

参数说明:

-d : 以后台服务方式运行
-l : 设置监听地址及端口(默认是22201)
-A : 数据页大小
-H : 数据保存目录
-B : 队列中每条数据的最大长度(字节)
-N : 使用内存缓冲方式保存数据至磁盘,从而获得极高性能。若无此参数,性能会很差
-R : 自动清理过期的日志
-u : 设置memcacheq进程账号
-L :日志缓存大小(默认是32K,1024表示1024K)

添加到开机启动:

全选复制放进笔记
vim /etc/rc.local

添加:

全选复制放进笔记
/usr/local/memcacheq/bin/memcacheq -d -r -uroot -p11212 -H /var/memcacheq/data -N -R -v -L 1024 -B 1024 > /var/memcacheq/logs/mq_error.log 2>&1

5、使用 PHP 连接

全选复制放进笔记
<?php
    $memcache_obj = new Memcache;
    $memcache_obj->connect('127.0.0.1', 11212);
    $memcache_obj->set('pushtask','38a7d8a504d69d1e2ac843b5804c04',0,0);
    $memcache_obj->close();
?>

<?php
    $memcache_obj = new Memcache;
    $memcache_obj->connect('127.0.0.1', 11212);
    $task = $memcache_obj->get('pushtask');
    //do your task here
    ...
    $memcache_obj->close();
?>

6、使用命令行连接

连接:

全选复制放进笔记
telnet 127.0.0.1 11212

添加:

全选复制放进笔记
格式:

set <queue name> <flags> 0 <message_len>
<put your message body here>
STORED

示例:

set test_queue 0 0 6
abcdef
STORED

获取:

全选复制放进笔记
格式:

get <queue name>
VALUE <queue name> <flags> <message_len>
<your message body will come here>
END

示例:

get test_queue
VALUE test_queue 0 13
first_message
END

查看队列:

全选复制放进笔记
stats queue
STAT test_queue 20/10    #表示队列test_queue里面有20条信息,读取了10条
END

删除整个队列:

全选复制放进笔记
格式:
delete <queue name>

示例:
delete test_queue
DELETED

MemcacheQ 的安装与使用的更多相关文章

  1. 持久化消息队列memcacheq的安装配置

    MemcacheQ 是一个基于 MemcacheDB 的消息队列服务器. 一.memcacheq介绍 特性: 1.简单易用 2.处理速度快 3.多条队列 4.并发性能好 5.与memcache的协议兼 ...

  2. MemcacheQ 安装与使用

    MemcacheQ 是一个基于 MemcacheDB 的消息队列服务器.官网地址:http://memcachedb.org/memcacheq/ 特点: 1.简单易用. 2.处理速度快. 3.可创建 ...

  3. MemcacheQ安装及使用

    一.MemcacheQ安装记录1.安装libevent查看是否已经安装了libeventrpm -qa|grep libevent如果没有安装使用yum安装yum install libevent l ...

  4. 在CentOS 6.2上安装 MemcacheQ 最新版

    1.      安装 yum install gcc cc make libevent libevent-devel 2.      安装Berkeley DB 下载:http://www.oracl ...

  5. MemcacheQ安装

    一.memcacheq介绍 特性: 1.简单易用 2.处理速度快 3.多条队列 4.并发性能好 5.与memcache的协议兼容 6.在zend framework中使用方便 memcacheq依赖于 ...

  6. 安装memcacheq

    1.下载memcacheq包    下载地址:http://code.google.com/p/memcacheq/downloads/list    解压包:# tar -zxvf memcache ...

  7. php 安装memcacheq

    berkeley: http://download.oracle.com/otn/berkeley-db/db-6.1.19.tar.gz?AuthParam=1408431634_4887d4468 ...

  8. 在linux下安装memcacheq

    #!/bin/bash mkdir ~/build cd ~/build wget http://download.oracle.com/berkeley-db/db-5.1.19.tar.gz .t ...

  9. 【转】Memcached安装

    解析:Memcached是什么? Memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度. 一.软件版本    ...

随机推荐

  1. log tree(merge)

    http://www-users.cs.umn.edu/~he/diff/p256-severance.pdf http://www.eecs.harvard.edu/~margo/cs165/pap ...

  2. lua堆栈操作常用函数学习二

    /* ** basic stack manipulation */ LUA_API int  <strong> (lua_gettop) (lua_State *L);  </str ...

  3. 采用libsvm进行mnist训练

    #coding:utf8 import cPickle import gzip import numpy as np from sklearn.svm import libsvm class SVM( ...

  4. VS产生sdf和ipch文件太大处理方案

    方法: 工具-->选项-->文本编辑器-->C/C++-->高级-->回退位置,把始终使用回退位置设置为true,回退位置已在使用,不警告也设置为true,回退位置设置为 ...

  5. C#中调用C++的dll的参数为指针类型的导出函数(包括二级指针的情况)

    严格来说这篇文章算不上C++范围的,不过还是挂了点边,还是在自己的blog中记录一下吧. C++中使用指针是家常便饭了,也非常的好用,这也是我之所以喜欢C++的原因之一.但是在C#中就强调托管的概念了 ...

  6. C#事件(event)解析

    事件(event),这个词儿对于初学者来说,往往总是显得有些神秘,不易弄懂.而这些东西却往往又是编程中常用且非常重要的东西.大家都知道windows消息处理机制的重要,其实C#事件就是基于window ...

  7. Web前端开发笔试&面试_05_other 2016104399MS

    1.数据传送的方式,get post 的区别是? 2.你要怎么绑定页码(比如给你第三页,)? 3.数据流是如何实现,用for 循环? 4.轮播怎么实现?用原生JS实现. 5.布局,B是固定宽度,A的内 ...

  8. Java collection 的一些介绍 集合

    collections主要提供一些,排序的算法,随机的,反向的,  collection 是容器的祖先接口 线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应 ...

  9. 相关性分析 -pearson spearman kendall相关系数

    先说独立与相关的关系:对于两个随机变量,独立一定不相关,不相关不一定独立.有这么一种直观的解释(不一定非常准确):独立代表两个随机变量之间没有任何关系,而相关仅仅是指二者之间没有线性关系,所以不难推出 ...

  10. HttpClient简介 post get -转自ibm

    HttpClient简介 HTTP 协议可能是现在 Internet 上使用得最多.最重要的协议了,越来越多的 Java 应用程序需要直接通过 HTTP 协议来访问网络资源.虽然在 JDK 的 jav ...