千万PV中RabbitMQ部署及原理详解
admin
2023-03-08 03:21:05
0

RabbitMQ介绍

    MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。

    RabbitMQ是流行的开源消息队列系统,用erlang语言开发。RabbitMQ是AMQP(高级消息队列协议)的标准实现。

RabbitMQ原理图示

千万PV中RabbitMQ部署及原理详解

Exchange四种匹配模式

  1. fanout:将生产者发送的信息推送到所有与他绑定的Queue;

  2. direct:精准匹配,当routing key=binding key时,将信息发送到对应的Queue;

  3. topic:模糊匹配,当满足部分规则时,将信息发送到对应的Queue;

  4. headers:不依赖routing key,binding key匹配规则,依据消息内容headers属性匹配。

关键概念介绍

  • Broker:简单来说就是消息队列服务器实体。

  • Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

  • Queue:消息队列载体,每个消息都会被投入到一个或多个队列。

  • Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。

  • Routing Key:路由关键字,exchange根据这个关键字进行消息投递。

  • vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。

  • producer:消息生产者,就是投递消息的程序。

  • consumer:消息消费者,就是接受消息的程序。

  • channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

消息队列的使用过程大概如下:

         (1)客户端连接到消息队列服务器,打开一个channel。
  (2)客户端声明一个exchange,并设置相关属性。
  (3)客户端声明一个queue,并设置相关属性。
  (4)客户端使用routing key,在exchange和queue之间建立好绑定关系。
  (5)客户端投递消息到exchange。

RabbitMQ实验搭建

配置信息:

千万PV中RabbitMQ部署及原理详解

配置步骤:

一、更改主机名(防止启动服务时出现故障):

mq01/mq02/mq03:

vim /etc/hostname

        mq01.localdomain

vim /etc/hosts

        192.168.218.156 mq01

        192.168.218.145 mq02

        192.168.218.139 mq03

二、构建独立的服务器

mq01/mq02/mq03:

systemctl stop firewalld.service

setenforce 0

yum install epel-release -y

yum install rabbitmq-server -y

ln -s /usr/lib/rabbitmq/bin/* /usr/bin/

rabbitmq-plugins list            //查看插件安装情况

rabbitmq-plugins enable rabbitmq_management           //启用rabbitmq_management管理

systemctl start rabbitmq-server.service       //开启服务

rabbitmqctl cluster_status          //检查集群状态(主机名未解析会报error)

              Cluster status of node rabbit@mq01 ...

              [{nodes,[{disc,[rabbit@mq01]}]},

              {running_nodes,[rabbit@mq01]},

             {cluster_name,<<"rabbit@mq01">>},

             {partitions,[]}]

             ...done.

三、构建RabbitMQ群集

mq01/mq02/mq03:

systemctl stop rabbitmq-server.service

[root@mq01 ~]# cat /var/lib/rabbitmq/.erlang.cookie

FDFUVYLHUIERZZNQUKPM        //同步三台cookie相同

systemctl start rabbitmq-server.service

内存节点 mq02/03

rabbitmqctl stop_app

rabbitmqctl join_cluster --ram rabbit@mq01    //以内存节点形式存在

rabbitmqctl start_app

rabbitmqctl cluster_status      //检查集群状态

            Cluster status of node rabbit@mq01 ...

            [{nodes,[{disc,[rabbit@mq01]},{ram,[rabbit@mq03,rabbit@mq02]}]},

            {running_nodes,[rabbit@mq03,rabbit@mq02,rabbit@mq01]},

            {cluster_name,<<"rabbit@mq01">>},

            {partitions,[]}]

            ...done.

http://192.168.218.156:15672/ //登录磁盘节点服务器 //默认用户名:guest 密码:guest

千万PV中RabbitMQ部署及原理详解

相关内容

热门资讯

黑龙江煤矿透水事故5名受困人员... 新华社哈尔滨12月23日电(记者王鹤、张涛) 记者23日从黑龙江丰源矿业有限公司大通沟煤矿透水事故现...
玩家最新攻略“葫芦三娃.怎么开... 玩家最新攻略“葫芦三娃.怎么开挂?”透视曝光猫腻您好,葫芦三娃这个游戏其实有挂的,确实是有挂的,需要...
前夫失联,女子卷入780余万巨... 一纸结婚证,曾是爱情的证明,如今却成为王瑾瑜难以挣脱的债务枷锁。她未曾料到,尽管与丈夫杨某结束了婚姻...
玩家最新攻略“西南互娱.可以开... 玩家最新攻略“西南互娱.可以开挂吗?”详细开挂教程您好,西南互娱这个游戏其实有挂的,确实是有挂的,需...
【第一消息】“摇钱树拼三张.到... 有 亲,根据资深记者爆料摇钱树拼三张是可以开挂的,确实有挂(咨询软件无需...
我来教教您“白金岛歪胡子.有挂... 网上科普关于“白金岛歪胡子有没有挂”话题很是火热,小编也是针对白金岛歪胡子作*弊开挂的方法以及开挂对...
终于懂了“经典联盟.怎么装挂?... 您好:经典联盟这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
终于了解“闲来贵州麻将.真的有... 家人们!今天小编来为大家解答闲来贵州麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
我来教教您“新三哥玩十三张.有... 我来教教您“新三哥玩十三张.有没有挂?”其实是有挂您好,新三哥玩十三张这个游戏其实有挂的,确实是有挂...
终于了解“麻友圈2挪来挪去.开... 您好:麻友圈2挪来挪去这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在...