分享好友 系统运维首页 频道列表

分布式队列服务MemcacheQ在Linux系统下的编译安装

Linux系统  2015-06-27 13:400

  MemcacheQ作为简单的分布式队列服务,因为对MemcacheQ不了解,不少人在MemcacheQ的安装上遇到了不少麻烦,小编就为大家详细介绍下MemcacheQ在Linux系统下的编译安装,以便大家有更详细的了解。

分布式队列服务MemcacheQ在Linux系统下的编译安装

  队列(Queue)是一种常用的数据结构。在队列这种数据结构中,最先插入的元素将会最先被取出;反之最后插入的元素将会最后被取出,因此队列又称为“先进先出”(FIFO:First In First Out)的线性表。

  加入元素的一端叫“队尾”,取出元素的一端叫“队头”。利用消息队列可以很好地异步处理数据的传送和存储,当遇到频繁且密集地向后端数据库中插入数据时,就可采用消息队列来异步处理这些数据写入。

  MemcacheQ是一款基于Memcache协议的开源消息队列服务软件,由于其遵循了Memcache协议,因此开发成本很低,不需要学习额外的知识便可轻松掌握。

  在最近的一个项目中也应用了MemcacheQ,下面我将分享一下MemcacheQ在Linux中的编译和安装过程。

  首先,MemcacheQ依赖于BerkeleyDB和Libevent,如果服务器中曾经安装过Memcached,那么Libevent应该已经存在了,否则就需要先下载安装Libevent。

  下载链接如下:

  Libevent:https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz

  Berkeley DB:http://download.oracle.com/otn/berkeley-db/db-6.0.30.tar.gz

  MemcacheQ:https://github.com/stvchu/memcacheq

  安装Libevent

  tar zvxf libevent-2.0.21-stable.tar.gz

  cd libevent-2.0.21-stable

  。/configure --prefix=/usr/local/libevent

  make && make install

  echo “/usr/local/libevent/lib” 》》 /etc/ld.so.conf

  ldconfig

  安装BerkeleyDB

  BerkeleyDB简介:BerkeleyDB是一个开源的文件数据库,介于关系数据库与内存数据库之间,使用方式与内存数据库类似,它提供的是一系列直接访问数据库的函数,而不是像关系数据库那样需要网络通讯、SQL解析等步骤。

  MemcacheQ依赖BerkleyDB用于队列数据的持久化存储,以免在MemcacheQ意外崩溃或中断时,队列数据不会丢失。

  tar zxvf db-6.0.30.tar.gz

  cd db-6.0.30/build_unix

  。。/dist/configure --prefix=/usr/local/berkeleydb

  make && make install

  ln -s /usr/local/berkeleydb/lib/libdb-6.0.so /usr/lib/

  echo “/usr/local/berkeleydb/lib/” 》》 /etc/ld.so.conf

  ldconfig

  安装MemcacheQ

  tar zxvf memcacheq-0.2.0.tar.gz

  cd memcacheq-0.2.0

  。/configure --prefix=/usr/local/memcacheq --with-bdb=/usr/local/berkeleydb --with-libevent=/usr/local/libevent --enable-threads

  make && make install 

  启动MemcacheQ

  Shell

  /usr/local/memcacheq/bin/memcacheq -d -uroot -r -l 127.0.0.1 -p11210 -H /usr/local/mcq -N -R -v -L 1024 -B 1024 》 /usr/local/mcq/logs/mcq_error.log 2》&1

  附:MemcacheQ参数

  -p 《num》 TCP监听端口(default: 22201)

  -U 《num》 UDP监听端口(default: 0, off)

  -s 《file》 unix socket路径(不支持网络)

  -a 《mask》 unix socket访问掩码(default 0700)

  -l 《ip_addr》 监听网卡

  -d 守护进程

  -r 最大化核心文件限制

  -u 《username》 以用户身份运行(only when run as root)

  -c 《num》 最大并发连接数(default is 1024)

  -v 详细输出 (print errors/warnings while in event loop)

  -vv 更详细的输出 (also print client commands/reponses)

  -i 打印许可证信息

  -P 《file》 PID文件

  -t 《num》 线程数(default 4)

  用PHP测试一下

  PHP

  《?php

  $mcq = new Memcache;

  $mcq-》connect(‘127.0.0.1’, 11210) or die (‘Connect Error!’);

  for ($i=1; $i《=5; $i++) {

  memcache_set($mcq, ‘k’, $i, 0, 0);

  }

  for ($i=1; $i《=6; $i++) {

  $queue = memcache_get($mcq, ‘k’);

  if ($queue === false) {

  echo “null\n”;

  } else {

  echo $queue.“\n”;

  }

  }

  memcache_close($mcq);

  ?》

  上面就是Linux编译安装MemcacheQ的方法介绍了,在安装MemcacheQ前,需要先安装Libevent和BerkeleyDB。

查看更多关于【Linux系统】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
Linux使用nginx反向代理。可实现域名指向特定端口
在配置80指向域名的时候出现端口占用,使用kill -9无法杀死端口,应使用下面的命令来杀死进程killall -9 nginx(使用完本命令需要再把配置过的配置文件重新启动。命令写在了PS下面)后在root权限下的nginx的sbin下使用./nginx -t(命令重启nginx并检查是否有语

0评论2023-02-13636

新换的 Fedora Core Linux 桌面,来秀一秀(多图)
1、桌面、终端、文件浏览器,已经设置好字体、自动挂载硬盘,不是很麻烦2、即时通讯:QQ,Skype3、firefox4、D4X、BT、电驴5、开发工具:eclipse netbeans6、openoffice 大开 word 公式文档,输出 PDF7、小企鹅输入法,支持微软双拼8、星际译王,linux 下免费

0评论2023-02-10695

Red Hat Linux、rhel 和 Fedora Core 以及 Centos 区别与联系 - spring3mvc学习笔记
Red Hat Linux、rhel 和 Fedora Core 以及 Centos 区别与联系1. Red Hat LinuxLinux是GNU/Linux的缩写,通常指各种Linux发行版的通称,Red Hat Linux是redhat最早发行的个人版本的linux, 其1。0版本于1994年11月3日发行。虽然其历史不及其它linux发行

0评论2023-02-10521

SUSE Linux 10、whitefin、Fedora Core Linux 6桌面效果大比拼 - 哼哼唧唧
SUSE Linux 10、whitefin、Fedora Core Linux 6桌面效果大比拼          Novell公司发布了SUSE Linux 10,向世人证明了一点,桌面版Linux已能和Windows相抗衡了。而接下来,拓林思公司的whitefin,走社区路线,三十分钟创造一个个性Linux,又为开发

0评论2023-02-10695

使用移动硬盘安装fedora14 使用移动硬盘安装Linux
以前一直使用DVD的方式安装,为响应绿色环保的号召,遂使用移动硬盘来完成此工作。原来用的是fedora13,下载Fedora-14-i386-DVD.iso后,把Fedora-14-i386-DVD.iso放到移动硬盘的fedora目录下,此移动硬盘的分区应为ext2, ext3, ext4, or FAT32,避免NTFS,将I

0评论2023-02-10406

关闭Fedora的防火墙 防火墙linux关闭
重启后生效 开启: chkconfig iptables on 关闭: chkconfig iptables off   或者 /sbin/chkconfig --level 2345 iptables off2) 即时生效,重启后失效 service 方式开启: service iptables start 关闭: service iptables stop iptables方式查看防火墙状

0评论2023-02-10457

Fedora Linux 下安装配置C开发环境Code::Blocks
一、提前的话 要说C语言和Linux的关系大家应该都不会陌生,Linux系统内核就是用C语言开发的,所以所有的Linux系统下面 都会有C的编译调试工具,不过这些工具都是命令式的,正式开发的话会很不方便。Fedora在安装的时候可以选择安装Fedora Eclipse,这个IDE很

0评论2023-02-10848

fedora加入启动项方法 linux添加启动项
配置开机启动服务/sbin/chkconfig httpd on [设置apache服务器httpd服务开机启动]/sbin/chkconfig --add mysqld [在服务清单中添加mysql服务]/sbin/chkconfig mysqld on             [设置mysql服务开机启动]另外,启动服务的方法/sbin/service h

0评论2023-02-10744

linux 安装 apache2.2.31
 Linux下安装和配置Apache 概要:本文介绍在CentOS5.4 Linux中安装和配置Apache2.2.14,并且实现Apache和Tomcat6的整合。文章分为三部分,分别是删除系统自带的Apache、安装Apache2.2.14和配置Apache2.2.14。 文章中介绍的知识也可以在其它版本的Linux中

0评论2023-02-10408

Debian rsyslog.conf Linux man page
NAME rsyslog.conf - rsyslogd(8) configuration fileDESCRIPTION The rsyslog.conf fileisthemainconfigurationfileforthe rsyslogd(8) which logs system messageson*nixsystems. Thisfile specifiesrules for logging.For special features see the rsyslo

0评论2023-02-10652

【Linux_Fedora_应用系列】_1_如何安装音乐播放器和mp3解码
  因为安装环境的不同,Fedora在安装后会安装不同的软件包。通常在安装的时候有多种选择:    1、桌面环境: 适合个人日常使用,安装包含办公软件(Fedora 默认安装Open Office)、娱乐影音软件,此版本不会默认不会安装source包,经常会在安装其他软件

0评论2023-02-10628

更多推荐