1.安装erlang虚拟机

  Rabbitmq基于erlang语言开发,所有需要安装erlang虚拟机。安装erlang有两种方式:

  第一种:使用yum安装:

wget -O /etc/yum.repos.d/epel-erlang.repo  http://repos.fedorapeople.org/repos/peter/erlang/epel-erlang.repo   # 把yum源安装到本地
yum install erlang

  第二种:下载源码编译安装:

yum groupinstall "development tools"
yum list *curse*
yum install ncurse-devel.xxxx #安装所需的ncurse
wget xxxx #http://www.erlang.org/download/otp_src_R16B.tar.gz
tar -xvf otp_src_xxx.tar.gz
cd otp_src_xxxx
./configure --without-javac #这个步骤的相关信息应该参考一下该目录下的README或INSTALL文件
make&&make install

  安装完毕后,在shell下执行erl看是否能打开eshell,用‘halt().’退出。

2.安装(rabbitmq-server-xxxx)

  使用rpm包安装 rpm -ivh rabbit-server-xxxx.rpm  (这样安装简单,不用配置path等)

  但是我在安装rabbitmq-server的过程中遇到了一个问题: 

  Error: Package: rabbitmq-server-3.0.2-1.noarch (/rabbitmq-server-3.0.2-1.noarch)
  Requires: erlang >= R12B-3
  You could try using --skip-broken to work around the problem
  You could try running: rpm -Va --nofiles --nodigest

  这是由于erlang的版本问题,其实是没有影响的,你可以使用rpm -ivh --nodeps rabbit-server-xxxx.rpm安装。

3.rabbitmq常用命令

  rabbitmq-server start  或者   service rabbitmq-server start     #启动rabbitmq
  rabbitmq-server stop 或者rabbitmqctl stop    #停止rabbitmq
  rabbitmqctl list_exchanges   #查看服务器种所有的路由信息
  rabbitmqctl list_bindings    #查看服务器种所有的路由与消息队列绑定信息
  rabbitmqctl list_queues  #查看服务器中所有的消息队列信息
  rabbitmqctl status  #查看运行信息
 
  rabbitmq-plugins enable rabbitmq_management  
  #启动rabbitmq的图形管理界面,这个操作必须重启rabbitmq,然后在web中 http://10.109.18.226:15672 用户名和密码都是guest guest。如果局域网无法访问设置防火墙过滤规则或关闭防火墙。
  具体的显示效果如下图:
  
  
  
 

4.rabbitmq可以搭建为集群

rabbitmq是用erlang开发的,集群使用起来非常方便,因为erlang天生就是一门分布式语言。

rabbitmq的集群包括内存节点、磁盘节点不过,如果再投递消息时,打开了消息的持久化,那么即使是内存节点,数据还是安全的放在磁盘。

rabbitmq的集群配置是依赖于/var/lib/rabbitmq/.erlang.cookie这个文件,该文件是集群节点进行通信的验证密钥,所有节点必须一致。

具体的配置信息见:http://windwrite.com/archives/206

5.rabbitmq的高可用性

rabbitmq集群并不保证队列的高可用性,尽管交换机、绑定这些可以复制到集群里的任何一个节点,但是队列的内容不会复制。

在集群里创建队列时,队列内容并不会复制到集群的每个节点上。RabbitMQ会挑选一个节点创建队列(这个选择算法是随机、轮询、还是基于资源负载的,有待深究),只有该节点上存储队列的完整内容。其他节点拥有队列的元数据(metadata),以及指向队列存储节点的指针。只有该队列是非持久的,客户端才能重新连接到集群里的其他节点,并重新创建队列。假如该队列是持久化的,那么唯一办法是将故障节点恢复起来。为什么RabbitMQ不将队列复制到集群里每个节点呢?这与它的集群的设计本意相冲突,集群的设计目的就是增加更多节点时,能线性的增加性能(CPU、内存)和容量(内存、磁盘)。当然RabbitMQ集群也支持队列复制(有个选项可以配置)。比如在有五个节点的集群里,可以指定某个队列的内容在2个节点上进行存储,从而在性能与高可用性之间取得一个平衡。

搭建架构:
一个haproxy,反向代理rabbitmq服务节点,rabbitmq服务只代理内存节点,保证速度。
web监控端代理磁盘节点,所有节点都是元数据都是同步的。
基本上可以保证如果不是所有的机器都down了,rabbitmq服务就不会down。具体的搭建见:http://www.tuicool.com/articles/YbYvIj

  

  

linux下安装rabbitmq的更多相关文章

  1. RabbitMQ教程(二) ——linux下安装rabbitmq

    安装过程参考官网: Installing on RPM-based Linux (RHEL, CentOS, Fedora, openSUSE) 首先需要安装erlang,参考:http://fedo ...

  2. 在Linux下安装RabbitMQ

    Installing on RPM-based Linux (CentOS, Fedora, OpenSuse, RedHat) 安装新版本的RabbitMQ出错: centos端口转发神器:soca ...

  3. linux下安装rabbitmq的rpm包问题记录

    安装rabbitmq的文章和帖子多如牛毛,不管是官网还是各个博客,这里附个Rabbitmq官网安装Rpm包的链接, http://www.rabbitmq.com/install-rpm.html 不 ...

  4. linux下安装rabbitmq 集群

    1.下载erlang官网地址 http://www.erlang.org/download 挑选合适的版本 然后 wget 比如目前18.3运行命令 wget http://erlang.org/do ...

  5. linux下安装rabbitmq以及在spring中进行集成

    ### 一.安装erlang 1. yum install ncurses-devel 2. ./configure --prefix=/usr/local/erlang20 --without-ja ...

  6. 【Linux】Linux下安装RabbitMQ服务

    一.安装步骤 1)安装erlang yum install -y erlang2)安装rabbitmq-serveryum install -y rabbitmq-server3)开启rabbitmq ...

  7. Linux 下安装RabbitMQ 3.6.1

    1.安装erlang 依赖 yum install -y gcc gcc-c++ unixODBC-devel openssl-devel ncurses-devel 2.安装erlang ### 设 ...

  8. centos 7环境下安装rabbitmq

    以 前在windows 7下面成功安装过rabbitmq,但是在windows 10下面安装失败,各种问题,各种解决方法都试过,还是不成功,最终放弃治疗. 后来经人指点,在linux下安装rabbit ...

  9. 在linux下安装配置rabbitMQ详细教程

    在linux下安装配置rabbitMQ详细教程 2017年12月20日 17:34:47 阅读数:7539 安装Erlang 由于RabbitMQ依赖Erlang, 所以需要先安装Erlang. Er ...

随机推荐

  1. 工具类 util.img

        /**     * @description transform emotion image url between code     * @author x.radish     * @pa ...

  2. mariaDB安装完成后设置root密码等初始化操作

    修改root密码1.以root身份在终端登陆(必须)2.输入 mysqladmin -u root -p password ex后面的 ex 是要设置的密码3.回车后出现 Enter password ...

  3. 2015 Multi-University Training Contest 6

    1001 Average 忍不住又补了一题. 只要枚举1与2之间1给2,2给1,什么都不做三种状态. 后面的情况都已经决定了. (估计只有我比赛的时候把a candy当成a个糖果了吧QAQ) # in ...

  4. sftp配置多用户权限

    sftp配置多用户权限   工作需要,用户上传文件到目录下,用ftp不太安全,选择sftp.让用户在自己的home目录下活动,不能ssh到机器进行操作.   下面开始干活. 查看ssh版本 ssh - ...

  5. @ResponseBody返回json时,json数据丢失或者报错

    现象: 1.报错:There is a cycle in the hierarchy! 2.返回至前台的json不完整,字段丢失. 错误原因: eg:entity1的属性有list<entiti ...

  6. Compile Time Assertion..

    The most seen assertion are during runtime, but this one is at compile time, to give the error more ...

  7. postgresql 修改属性

    up vote2down votefavorite From this article, I tried to update or delete property of a JSONB column: ...

  8. Python 2 中的编码

    在 Python 尤其是 Python2 中,编码问题是困扰开发者尤其初学者的一大问题.什么 Unicode/UTF-8/str ,又是 decode/encode 的,搞得人头都大了.其实不然,这有 ...

  9. 关于C++中字符的转换

    VS的工程属性中我们常会设置Character Set:

  10. MinGW 运行C++程序的方法

    1:安装好 MinGW 及 GCC 编译器后 , 当然 MinGW 全安装最保险了,不会太费劲 2:配置环境变量(注:可能需要重启后生效) 计算机 --> 属性 --> 高级系统设置 -- ...