zoukankan      html  css  js  c++  java
  • RockeyMQ消息处理

    1:topic下面的queue 奇偶数会影响消费端的消费数量,

    假设 4个队列,8个消息,每个节点各自消费两条,如果不对等的话,就没办法做一个负载均衡

    队列的数量要大于consumer数量,不然多出来的consumer无法分配到queue,消息没办法消费,需要控制队列大于消费端

    2:集群模式和广播模式

    集群模式:消息只会被一个consumser消费一次,比如下单业务等;

    广播模式:消息会被每个Consumer消费,比如群发公告等,广播模式中的ConsumerGroup暂时无用

    通过 setMessageModel 进行修改

    3:一个Message里面只有一个topic,一个topic可以有多个tag,比如一个任务, 分为垫付任务,礼品任务,高权重任务,topic就是任务大类,tag就是任务大类的细分,二级类目,consumer端接受消息过滤有很多种

    1:通过制定的tag接受

    product

    consumer

    2:通过 * 监听,获取topic下面的全部消息

    3:通过 || 运算符监听,只要匹配到就接受

    4:通过SLQ92监听,支持 sql运算符  < >  >= <= =  is null or and not  等

    启动报错

    org.apache.rocketmq.client.exception.MQClientException: CODE: 1  DESC: The broker does not support consumer to filter message by SQL92

    解决方法:增加配置

    进入 /distribution/target/apache-rocketmq/conf/2m-2s-async  主修改 

    broker-a.properties

    添加配置

    enablePropertyFilter=true

    停掉之前的brokey服务   sh bin/mqshutdown broker

    重启brokey

    nohup sh bin/mqbroker -c conf/2m-2s-async/broker-a.properties &

    从节点的话进入  /distribution/target/apache-rocketmq/conf/2m-2s-async

    修改   

    broker-a-s.properties 添加配置
     
     
    回到 
    mqbroker目录  停掉之前服务  启动  
    nohup sh bin/mqbroker -c conf/2m-2s-async/broker-a-s.properties &

    再次启动服务

    product

    message.putUserProperty("orderNum","1");

    consumer

    过滤的话分为brokey过滤和consumer端过滤

    brokey过滤:能减少一些无用的消息发送,节约带宽,会增加Brokey的负担

    consumer过滤:能够减少brokey的压力

    在brokey过滤首先product把tag转成哈希码发送到brokey,然后会去遍历queue里面的tag,和订阅方传递过来的tag进行hashcode匹配,不一样的劵就跳过,一样的话就发送到consumer,

    然后consumer 防止hash 碰撞 会把tag 哈希码装换成原生的字符串进行对比过滤

  • 相关阅读:
    当el-input输入多行内容,反显时,字符串需要换行显示
    【前端】记录自己在leetcode上的刷题之路
    本地提代码到github上,不显示贡献值的问题
    关于对象的深拷贝和浅拷贝
    js判断两个数值区间是否存在重叠或覆盖
    解决vue-print-nb打印el-table,不同分辨率下,打印显示不全的问题
    vue实现置顶功能
    el-table设置自定义表头,当表头内容过长时,鼠标悬浮显示完整内容
    省市用element级联选择器,构造树形结构的数据(两层)
    STL隐蔽知识点
  • 原文地址:https://www.cnblogs.com/HuangXingLei/p/12641279.html
Copyright © 2011-2022 走看看