详解rabbitmq

1 概述

1.1 认识消息队列

message queue 简称MQ,是一种跨进程的通信机制,用于上下游传递信息

MQ作为消息的中间件,最主要的作用是各个系统之间的消息传递进行"解耦",mq是数据可靠性的重要保证

1.2 什么是rabbitMq

rabbitmq是全世界最火的开源代理服务器,再全世界有35000个项目部署再rabbitMq

rabbitmq 几乎支持所有的操作系统与编程语言

rabbitmq提供了高并发,高可用的部署方案,支持多种消息协议,容易部署和维护

1.3 rabbitmq 和其他mq比较

rabbitmqactivemqkafkarocketmq

社区活跃度非常活跃非常活跃活跃不活跃

持久化支持支持支持支持

并发吞吐量高一般极高极高

数据可靠性极高一般高高

生态完整性很好很好很好一般

用户总量多多==>一般较多少

应用场景分布式 高可靠的交易系统传统业务系统日志处理和大数据应用互联网高并发,高可用

2 安装

基于docker 安装rabbitmq#指定版本,该版本包含了web控制页面

docker pull rabbitmq:management

#方式一:默认guest 用户,密码也是 guest

docker run -d --hostname my-rabbit --name rabbit -p 15672:15672 -p 5672:5672 rabbitmq:management

#方式二:设置用户名和密码

docker run -d --hostname my-rabbit --name rabbit -e RABBITMQ_DEFAULT_USER=user -e RABBITMQ_DEFAULT_PASS=password -p 15672:15672 -p 5672:5672 rabbitmq:management

方式三:jar包安装

1 下载esl-erlang_21.0-1~centos~7_amd64.rpm**

Erlang运行环境RPM包

2. 下载rabbitmq-server-3.7.7-1.el7.noarch.rpm**

rabbitmq服务器程序

3. mkdir /usr/local/temp*

4. cd /usr/local/temp**

5. 通过XFTP将文件上传至temp目录**

6. rpm -ivh --nodeps esl-erlang_21.0-1~centos~7_amd64.rpm**

安装RPM包

7.rpm -ivh --nodeps rabbitmq-server-3.7.7-1.el7.noarch.rpm**

8. rabbitmq-plugins enable rabbitmq_management**

启用控制台

9. rabbitmq-server

10. chown rabbitmq:rabbitmq /var/lib/rabbitmq/.erlang.cookie**

启用服务

11. 防火墙放行5672/15672端口

访问

http://localhost:15672/

3 常用命令

3.1启动和关闭

rabbitmq-server 前台启动服务

rabbitmq-server -detached 后台启动服务

rabbitmqctl stop 停止服务

3.2 终止和启动应用

rabbitmqctl start_app 启动应用

rabbitmqctl stop_app 终止应用

3.3 用户管理

rabbitmqctl add_user {username} {password}

– 创建新用户

rabbitmqctl delete_user {username}

– 删除用户

rabbitmqctl change_password {username} {newpassword}

– 重置密码

rabbitmqctl set_user_tags {username} {tag}

– 授予用户角色(Tag)

rabbitmqctl set_permissions -p / user_admin '.' '.' '.*'

设置用户允许访问的vhost

3.4 rabbitmq 四种tag

超级管理员(administrator)

– 可登陆管理控制台(启用management plugin的情况下),可查看所有 的信息,并且可以对用户,策略(policy)进行操作。

监控者(monitoring)

– 登陆管理控制台(启用management plugin的情况下),同时可以查看 rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等)

策略制定者(policymaker)

– 可登陆管理控制台(启用management plugin的情况下), 同时可以对 policy进行管理。但无法查看节点的相关信息(上图红框标识的部分)

普通管理者(management)

仅可登陆管理控制台(启用management plugin的情况下),无法看到 节点信息,也无法对策略进行管理。

4 第一次MQ通信

4.1 AMQP

AMQP,即Advanced Message Queuing Protocol,一个提供统 一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开 放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间 件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等 条件的限制。Erlang中的实现有 RabbitMQ等

4.2 基本概念

Producer:生产者,消息的提供者

Consumer:消费者,消息的使用者

Message:消息,程序间的通信的数据

Queue:队列,消息存放的容器,消息先进先出

Vhost:虚拟主机,相当于MQ的“数据库” ,用于存储队列

5 rabbitmq的工作模式

1  一个生产这  多个消费者  一个消息 只适用于一个消费者

2发布订阅  交换机  (把消息生成副本) 多个消费者都可以看一个消息,消息会重复发给一个消费者

3 路由器  根据一定条件把消息 送给消费者,再3的基础上强调了根据规则

4  主题模式  定义一个表达式规程  按照规则把消息送给指定的人(再4 的基础上根据模糊匹配实现)

5 Rpc 远程调用  不同语言(dubbo  springcloud  webservice都可以实现,rpc不是mq的强项)

6 Work Queue工作队列


本讲将创建一个工作队列(Work Queue),它会发 送一些耗时的任务给多个工作者(Worker)。

在多个消息的情况下,Work Queue会将消息分派给 不同的消费者,每个消费者都会接收到不同的消息,并且可以根据处理消息的速度来接收消息的数量,进

而让消费者程序发挥最大性能。

Work Queue特别适合在集群环境中做异步处理,能最大程序发挥每一台服务器的性能。

7 发布(Publish)/订阅(Subscribe)模式


发布/订阅模式中,生产者不再直接与队列绑定, 而是将数据发送至“交换机Exchange

交换机Exchange用于将数据按某种规则送入与之绑定的队列,进而供消费者使用。 发布/订阅模式中,交换机将无差别的将所有消 息送入与之绑定的队列,所有消费者拿到的消息完全相同,交换机的类型被称为fanout

7.1 发布/订阅模式使用场景

发布订阅模式因为所有消费者获得相同的消息,所以 特别适合“数据提供商与应用商

例如:中国气象局提供“天气预报”送入交换机,网易、新浪、百度、搜狐等门户接入通过队列绑定到该

交换机,自动获取气象局推送的气象数据。

8 路由Routing模式

路由(Routing)模式是在发布订阅模式 基础上的变种。 发布订阅模式是无条件将所有消息分发给 所有消费者队列。

路由模式则是交换机根据Routing Key有条件的将数据筛选后发给消费者队列。

路由模式下交换机的类型被称为direct,队列和交换机可以自己绑定

9 主题Topic模式

主题Topic模式是在Routing模式基础上, 提供了对RouteKey模糊匹配的功能,可以

简化程序的编写。

主题模式下,模糊匹配表达式规则为

* 匹配单个关键字

# 匹配所有关键字

主题模式下交换机的类型被称为topic。队列和交换机可以自己绑定

10  Confirm & Return

Confirm代表生产者将消息送到Broker时产生的状态,后续

会出现两种情况:

ack 代表Broker已经将数据接收。

nack 代表Broker拒收消息。原因有多种,队列已满,限流,IO异常...

Return代表消息被Broker正常接收(ack)后,但Broker没

有对应的队列进行投递时产生的状态,消息被退回给生产者。

注意:上面两种状态只代表生产者与Broker之间消息投递的

情况。与消费者是否接收/确认消息无关。

11 RabbitMQ集群架构模式


RabbitMQ集群包含四种架构模式:

主备模式 (Warren)

镜像模式 (Mirror)

远程模式 (Shovel)

多活模式 (Federation)

11.1 主备模式 (Warren)

主备模式; 实现rabbitmq的高可用集群,一般在并发数量不高的情况下使用。这种模型非常好用并且简单,主备模式也称为 warren模式

11.2  镜像模式 (Mirror)

集群模式非常经典的就是mirror 镜像模式 ,保证数据100% 不丢失,实际工作中也是使用最多的。并且实现集群非常简单,互联网大厂通常会构建这种集群模式

11.3 远程模式 (Shovel)

远程模式可以实现双活的一种模式,简称shovel,所谓shovel就是我们可以把消息进行不同的数据中心复制的工作,我们可以地域让两个mq集群互联

11.4 多活模式 (Federation)

多活模式是实现异地数据复制的主流模式,因为shovel 模式配置比较复杂,所以一般来说实现异地集群都是用这种双活或者多活模式,这种模型需要依赖rabbitmq 的federation插件,可以实现持续的amqp数据通信。

12 搭建mirror集群

12.1 准备两个已安装好RabbitMQ的Centos环境

修改hostname

vim /etc/hostname

m1

m2

加入主机列表 vim /etc/hosts

vim /etc/hosts

192.168.132.137 m1

192.168.132.139 m2

12.2 准备工作-开放防火墙端口

开放防火墙 4369/5672/15672/25672端口

firewall-cmd --zone=public --add-port=4369/tcp --permanent

firewall-cmd --zone=public --add-port=5672/tcp --permanent

firewall-cmd --zone=public --add-port=15672/tcp --permanent

firewall-cmd --zone=public --add-port=25672/tcp --permanent

firewall-cmd --reload

重启两台主机

– reboot

12.3 复制.erlang.cookie

.erlang.cookie是erlang分布式的token文件,集群内所有设备要

持有相同的.erlang.cookie文件才允许彼此通信。

find / -name *.cookie

scp /var/lib/rabbitmq/.erlang.cookie 192.168.132.134:/var/lib/rabbitmq/

在两台电脑上执行chmod进行授权

chmod 400 /var/lib/rabbitmq/.erlang.cookie

12.4 配置镜像集群

在m2服务器上执行下面的命令将与m1服务器进行复制

rabbitmqctl stop_app 暂停服务

rabbitmqctl join_cluster rabbit@m1 加入到m1的集群

rabbitmqctl start_app 启动服务

rabbitmqctl cluster_status 验证集群结果

13 利用haproxy负载均衡

13.1镜像模式遇到的问题

13.2 HAProxy 代理服务器

HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)

和HTTP(第七层)应用的代理软件,支持虚拟主机,它是免费、

快速并且可靠的一种解决方案。

RabbitMQ集群镜像模式中,HAProxy用于做Tcp,提供节点负载

均衡(LB-LoadBalance)与故障发现。

13.3 haproxy安装

yum install haproxy  //安装

rpm -ql haproxy  //查看安装是不是成功

find / -name haproxy.cfg  //找到核心配置文件

haproxy -f /etc/haproxy/haproxy.cfg    //启动命令

13.4 haproxy.cfg配置详解

listen rabbitmq_cluster

bind 0.0.0.0:5672 #通过5672对M1、M2进行映射

option tcplog #记录tcp 连接的状态和时间

mode tcp #四层协议代理,即对TCP协议转发

option clitcpka #开启TCP的Keep Alive(长连接模式)

timeout connect 1s #haproxy与mq建立连接的超时时间

timeout client 10s #客户端与haproxy最大空闲时间。

timeout server 10s #服务器与haproxy最大空闲时间。

balance roundrobin #采用轮询转发消息

#每5秒发送一次心跳包,如连续两次有响应则代表状态良好,

#如连续三次没有响应,则视为服务故障,该节点将被剔除。

server node1 192.168.132.137:5672 check inter 5s rise 2 fall 3

server node2 192.168.132.139:5672 check inter 5s rise 2  2 fall 3

listen http_front

#监听端口

bind 0.0.0.0:1080

#统计页面自动刷新时间

stats refresh 30s

#统计页面url

stats uri /haproxy?stats

#统计页面用户名和密码设置

stats auth admin:admin

访问 :http://am3:1080/ha

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343