一、简介 MQ(Message Queue,消息队列)是一款消息中间件,一般以集群方式部署,主要提供消息的接受和发送,实现各微服务之间的消息异步。1、集群原理 rabbitmq是依据erlang的分布式特性(RabbitMQ底层是通过Erlang架构来实现的,所以rabbitmqctl会启动Erlang节点,并基于Erlang节点来使用Erlang系统连接RabbitMQ节点,在连接过程中需要正确的Erlang Cookie和节点名称,Erlang节点通过交换Erlang Cookie以获得认证)来实现的,所以部署rabbitmq分布式集群时要先安装erlang,并把其中一个服务的cookie复制到另外的节点。 rabbitmq集群中,各个rabbitmq为对等节点,即每个节点均提供给客户端连接,进行消息的接收和发送。节点分为内存节点和磁盘节点,一般的,均应建立为磁盘节点,为了防止机器重启后的消息消失; RabbitMQ的Cluster集群模式一般分为两种,普通模式和镜像模式。消息队列通过rabbitmq HA镜像队列进行消息队列实体复制。 普通模式下,以两个节点(rabbit01、rabbit02)为例来进行说明。对于Queue来说,消息实体只存在于其中一个节点rabbit01(或者rabbit02),rabbit01和rabbit02两个节点仅有相同的元数据,即队列的结构。当消息进入rabbit01节点的Queue后,consumer从rabbit02节点消费时,RabbitMQ会临时在rabbit01、rabbit02间进行消息传输,把A中的消息实体取出并经过B发送给consumer。所以consumer应尽量连接每一个节点,从中取消息。即对于同一个逻辑队列,要在多个节点建立物理Queue。否则无论consumer连rabbit01或rabbit02,出口总在rabbit01,会产生瓶颈。 镜像模式下,将需要消费的队列变为镜像队列,存在于多个节点,这样就可以实现RabbitMQ的HA高可用性。作用就是消息实体会主动在镜像节点之间实现同步,而不是像普通模式那样,在consumer消费数据时临时读取。缺点就是,集群内部的同步通讯会占用大量的网络带宽。2、系统架构概念说明:Broker:它提供一种传输服务,它的角色就是维护一条从生产者到消费者的路线,保证数据能按照指定的方式进行传输Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列Queue:消息的载体,每个消息都会被投到一个或多个队列Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来Routing Key:路由关键字,exchange根据这个关键字进行消息投递vhost:虚拟主机,一个broker里可以有多个vhost,用作不同用户的权限分离Producer:消息生产者,就是投递消息的程序Consumer:消息消费者,就是接受消息的程序Channel:消息通道,在客户端的每个连接里,可建立多个channel二、环境准备1、系统环境主机名系统IP用途masterCentOS7.4192.168.56.129磁盘节点slave1CentOS7.4192.168.56.130内存节点slave2CentOS7.4192.168.56.131内存节点2、暂时关闭防火墙和selinux3、设置三个节点主机名hosts[root@master ~]# cat /etc/hosts192.168.56.129 master192.168.56.130 slave1192.168.56.131 slave2三、搭建服务1、安装最新repo源[root@master ~]# yum -y install epel-release2、安装三个节点的rabbitmq-server软件包[root@master ~]# yum -y install rabbitmq-server3、查看已安装的插件[root@master ~]# rabbitmq-plugins list4、启动管理服务(三个节点)[root@master ~]# rabbitmq-plugins enable rabbitmq_management5、分别启动rabbitmq服务(三个节点)[root@master ~]# systemctl start rabbitmq-server.servicerabbitmq集群部署1、关闭服务(三个节点)[root@master ~]# systemctl stop rabbitmq-server.service2、进入cookie文件目录,配置(各节点需要有相同序列号值)[root@master ~]# cd /var/lib/rabbitmq/[root@master rabbitmq]# vim .erlang.cookie3、再启动rabbitmq服务[root@master rabbitmq]# systemctl start rabbitmq-server.service4、关闭rabbitmq应用开发云主机域名(只关闭slave1和slave2)[root@master rabbitmq]# rabbitmqctl stop_app5、将slave1、slave2加入master,使它们成为一个集群。再次启动应用[root@slave1 ~]# rabbitmqctl join_cluster –ram rabbit@master[root@slave1 ~]# rabbitmqctl start_app6、分别查看rabbitmq服务器状态[root@master ~]# rabbitmqctl cluster_status7、通过客户端浏览器进行访问RabbitMQ (用户名:guest 密码:guest)http://192.168.56.129:15672
一.网络相关基本概念 1.网络通信协议:是一种网络通用语言,为连接不同操作系统和不同硬件体系结构的互联网络引提供通信支持,是一种网络通用语言.通信协议的具体种类有很多,主要有:UDP协议和T CP协议 2.UDP协议:是User Datagram Protoc…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。