RocketMQ集群解决方案

来源:互联网 发布:appsevr php升级 编辑:程序博客网 时间:2024/06/11 00:07

一、应用场景及性能(在使用RocketMq之前我们要思考这框架能帮我们解决什么现实问题)


  1、异步处理,将不是必须的业务逻辑,进行异步处理,比如注册之后短信、邮箱的发送

  2、应用解耦,
       订单系统:用户下单后,订单系统完成持久化处理,将消息写入消息队列,返回用户订单下单成功。
       库存系统:订阅下单的消息,采用拉/推的方式,获取下单信息,库存系统根据下单信息,进行库存操作。
       假如:在下单时库存系统不能正常使用。也不影响正常下单,因为下单后,订单系统写入消息队列就不再关心其他的后续操作了。实现订单系统与库存系统的应用解耦。

  3、流量削锋,也是消息队列中的常用场景,一般在秒杀或团抢活动中使用广泛。
     应用场景:秒杀活动,一般会因为流量过大,导致流量暴增,应用挂掉。为解决这个问题,一般需要在应用前端加入消息队列。
     3.1、可以控制活动的人数;
     3.2、可以缓解短时间内高流量压垮应用;
     3.3、用户的请求,服务器接收后,首先写入消息队列。假如消息队列长度超过最大数量,则直接抛弃用户请求或跳转到错误页面;
     3.4、秒杀业务根据消息队列中的请求信息,再做后续处理。

  4、日志处理
  
  5、消息通讯
        消息通讯是指,消息队列一般都内置了高效的通信机制,因此也可以用在纯的消息通讯。比如实现点对点消息队列,或者聊天室等。


  6、性能:
        RocketMQ单机也可以支持亿级的消息堆积能力
        单机写入TPS单实例约7万条/秒,单机部署3个Broker,可以跑到最高12万条/秒,消息大小10个字节

二、RocketMQ网络部署图


  网络集群节点描述

     1、Name Server 可集群部署,节点之间无任何信息同步。


     2、Broker(消息中转角色,负责存储消息,转发消息) 部署相对复杂,Broker 分为Master 与Slave,一个Master 可以对应多个Slave,但是一个Slave 只能对应一个Master,Master 与Slave 的对应关系通过指定相同的BrokerName,不同的BrokerId来定 义,BrokerId为0 表示Master,非0 表示Slave。Master 也可以部署多个。每个Broker 与Name。


    3、Producer 与Name Server 集群中的其中一个节点(随机选择)建立长连接,定期从Name Server 取Topic 路由信息,并向提供Topic 服务的Master 建立长连接,且定时向Master 发送心跳。Producer 完全无状态,可集群部署。


    4、Consumer 与Name Server 集群中的其中一个节点(随机选择)建立长连接,定期从Name Server 取Topic 路由信息,并向提供Topic 服务的Master、Slave 建立长连接,且定时向Master、Slave 发送心跳。Consumer既可以从Master 订阅消息,也可以从Slave 订阅消息,订阅规则由Broker 配置决定。



三、实际集群部署操作步骤(采用多Master多Slave,异步复制集群模式进行部署)
1、下载部署包 alibaba-rocketmq-3.2.6.tar.gz
2、将下载的包放入并解压到Linux系统指定目录中,在这里我以/home/目录为例,准备两台服务器分别为       
     192.168.113.138、192.168.113.134 下面步骤就不区分是在哪台服务器进行操作了,步骤都是一样的
     -- 解压
     #tar -zxvf alibaba-rocketmq-3.2.6.tar.gz
     -- 修改配置文件由于我们采用的是异步复制模式,所以需要修改2m-2s-async配置内容,-- 2m-2s-sync 是代表同步复制模式 ,2m-noslave是代表单击模式
     #修改Master
     #vim  /home/alibaba-rocketmq/conf/2m-2s-async/broker-a.properties 
     #修改Salves
     #vim  /home/alibaba-rocketmq/conf/2m-2s-async/broker-a-s.properties
#Broker所属哪个集群,默认【DefaultCluster】
brokerClusterName=DefaultCluster
#本机主机名
brokerName=hadoop1
#BrokerId,必须是大等于0的整数,0表示Master,>0表示Slave
brokerId=0
#删除文件时间点,默认凌晨4点
deleteWhen=04
#文件保留时间,默认48小时
fileReservedTime=48
#Broker的角色 - ASYNC_MASTER 异步复制Master - SYNC_MASTER 同步复制
brokerRole=ASYNC_MASTER
#刷盘方式 - ASYNC_FLUSH 异步刷盘 - SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH


#Name Server地址
namesrvAddr=192.168.113.137:9876;192.168.113.134:9876
#Broker对外服务的监听端口,默认【10911】
listenPort=10911
defaultTopicQueueNums=4
#是否允许Broker自动创建Topic,建议线下开启,线上关闭,默认【true】
autoCreateTopicEnable=true
#是否允许Broker自动创建订阅组,建议线下开启,线上关闭,默认【true】
autoCreateSubscriptionGroup=true
mapedFileSizeCommitLog=1073741824
mapedFileSizeConsumeQueue=50000000
destroyMapedFileIntervalForcibly=120000
redeleteHangedFileInterval=120000
diskMaxUsedSpaceRatio=88
#消息队列存储的根目录,需要自定义目录路径
storePathRootDir=/usr/local/alibaba-rocketmq/data/store
#消息队列存储的实际目录,需要自定义目录路径
storePathCommitLog=/usr/local/alibaba-rocketmq/data/store/commitlog
maxMessageSize=65536
flushCommitLogLeastPages=4
flushConsumeQueueLeastPages=2
flushCommitLogThoroughInterval=10000
flushConsumeQueueThoroughInterval=60000
checkTransactionMessageEnable=false
sendMessageThreadPoolNums=128
pullMessageThreadPoolNums=128

 3、启动RocketMQ
 3.1、在192.168.113.138启动Master、Slave服务(进入/home/alibaba-rocketmq/bin 目录)
 #nohup sh mqnamesrv 1>/home/alibaba-rocketmq/log/ng.log 2>/home/alibaba-rocketmq/log/ng-error.log &
 #nohup sh mqbroker -n 192.168.113.138:9876 -c /home/alibaba-rocketmq/conf/2m-2s-async/broker-a.properties >/home/alibaba-rocketmq/log/mq.log &  
 #nohup sh mqbroker -n 192.168.113.138:9876 -c /home/alibaba-rocketmq/conf/2m-2s-async/broker-a-s.properties >/home/alibaba-rocketmq/log/mq.log &

 3.2、在192.168.113.134启动Master、Slave服务(进入 /home/alibaba-rocketmq/bin 目录)
 #nohup sh mqnamesrv 1>/home/alibaba-rocketmq/log/ng.log 2>/home/alibaba-rocketmq/log/ng-error.log &
 #nohup sh mqbroker -n 192.168.113.134:9876 -c /home/alibaba-rocketmq/conf/2m-2s-async/broker-a.properties >/home/alibaba-rocketmq/log/mq.log &  
 #nohup sh mqbroker -n 192.168.113.134:9876 -c /home/alibaba-rocketmq/conf/2m-2s-async/broker-a-s.properties >/home/alibaba-rocketmq/log/mq.log &

 3.3、JPS检查
 #jps 
查看是否有如下进程,如果有则服务启动成功:
BrokerStartup
NamesrvStartup
关停服务命令:
#sh mqshutdown namesrv  
#sh mqshutdown broker 

3.4、常用命令
--查看所有消费组group
#sh mqadmin consumerProgress -n 192.168.113.134:9876
--看指定消费组下的所有topic数据堆积情况
#sh mqadmin consumerProgress -n 192.168.113.134:9876 -g myProducer
查看指定报文信息 C0A8718A00002A9F000000000000F790 指的是报文在MQ队列中的MSG_ID
#sh mqadmin queryMsgById -n 192.168.113.138:9876 -i C0A8718A00002A9F000000000000F790

--查看Topic 列表信息
#sh mqadmin topicList  -n 192.168.113.138:9876
--查看topic信息列表详情统计
#sh mqadmin topicstatus -n 192.168.113.138:9876 -t Topic
--查看集群消息
#sh mqadmin clusterList  -n 192.168.113.138:9876  



0 0
原创粉丝点击