memcacheq安装与消息队列
来源:互联网 发布:遥感软件 编辑:程序博客网 时间:2024/06/07 00:00
在处理业务逻辑时有可能遇到高并发问题,例如商城秒杀、微博评论等。如果不做任何措施可能在高瞬间造成服务器瘫痪,如何解决这个问题呢?队列是个不错的选择。队列(Queue)又称先进先出(First In First Out)利用消息队列可以很好地异步处理数据传送和存储,当你向数据库中写入数据就可采取消息队列来异步插入。只要有并发限制的地方基本都可以使用队列来解决。这里先重点介绍一下memcacheq。
持久化消息队列memcacheq是一个轻量级的消息队列。依附于Berkeley DB和libevent。Berkeley DB用于持久化存储队列的数据,避免在memcacheq出问题时造成数据丧失。接下来看一下安装过程,首先下载libevent、BerkeleyDB5.0、memcacheq-0.2.0,下载地址:
安装步骤:
1、先下载文件:
wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz --no-check-certificate
wget http://download.oracle.com/berkeley-db/db-6.0.30.tar.gz
wget https://memcacheq.googlecode.com/files/memcacheq-0.2.0.tar.gz
2、解压安装
(1)libevent:
$ 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:
$ 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
$ 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
3、启动服务
建立相关目录:
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
每次按照存入顺序读取一条(先进先出)
持久化消息队列memcacheq是一个轻量级的消息队列。依附于Berkeley DB和libevent。Berkeley DB用于持久化存储队列的数据,避免在memcacheq出问题时造成数据丧失。接下来看一下安装过程,首先下载libevent、BerkeleyDB5.0、memcacheq-0.2.0,下载地址:
安装步骤:
1、先下载文件:
wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz --no-check-certificate
wget http://download.oracle.com/berkeley-db/db-6.0.30.tar.gz
wget https://memcacheq.googlecode.com/files/memcacheq-0.2.0.tar.gz
2、解压安装
(1)libevent:
$ 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:
$ 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
$ 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
3、启动服务
建立相关目录:
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
4、php操作代码
存入:$memcacheq_obj = new memcache();$memcacheq_obj->connect("地址",端口号);$res = $memcacheq_obj->set('队列名',‘值’,0,0);读取:$arr = $memcacheq_obj->get('队列名');
每次按照存入顺序读取一条(先进先出)
0 0
- memcacheq安装与消息队列
- php消息队列MemcacheQ 安装与使用
- MemcacheQ(消息队列)
- 分布式持久化消息队列memcacheq的安装部署
- 持久化消息队列memcacheq的安装配置
- sina微博队列memcacheq 服务安装与原理
- sina微博队列memcacheq 服务安装与原理
- sina微博队列memcacheq 服务安装与原理
- sina微博队列memcacheq 服务安装与原理
- MemcacheQ 安装与使用
- MemcacheQ 安装与使用
- Memcache 持久化消息队列MemcacheQ
- 消息队列服务器 memcacheq的搭建
- 持久化消息队列之MEMCACHEQ
- Memcache 持久化消息队列MemcacheQ
- memcacheq 服务安装与原理
- memcacheq的安装与配置
- memcacheq的安装与配置
- 数据结构实验之二叉树五:层序遍历(数组模拟队列)
- javascript超级简单的写出轮播图
- HDFS系统结构
- 只有五行的算法--Floyd-Warsha
- Python 读写文件 中文乱码 错误TypeError: write() argument must be str, not bytes+
- memcacheq安装与消息队列
- 搭建FTP服务器
- 第十一周项目1--(2)二叉树构造算法的验证--由顺序存储结构转为二叉链存储结构
- $.ajax传参数数组的情况
- poj1887(最长下降子序列)
- BZOJ 2434: [Noi2011]阿狸的打字机(fail树+树状数组)
- vs调用matlab的动态库(matlab为卡尔曼滤波相关算法)
- GIT 安装和使用
- 数据结构==翻译程序