rocketmq简记

rocketmq服务组成:
1.nameserver broker 注册等,多节点
2.broker 消息接收和分发,持久化等,多节点,主从模式保证可用性;模式同步master和异步master,在同步master情况下,slave节点保存成功后,给客户端返回成功.硬盘刷新方式有同步刷新和异步刷新,在同步刷新模式下,当消息写入硬盘后,返回成功.
3.producer 生产者:
3.1 同步发送模式 send
3.2 异步发送模式 sendcallback
3.3 带队列选择的同步/异步发送 select
3.4 one-way方式发送,可用于log-collection等
4.消费者
4.1 push型消费,长pull实现,基于线程池,可配置批量消费,默认批量值1
4.2 pull主动拉取消费,客户端编码较复杂
监听器:
4.3 并发监听消费消息
4.4 顺序监听消息消费,保证每队列消息消费顺序型

hook:跟拦截器功能类似
rpchook:再netty发送消息时实现拦截

public interface RPCHook {
    public void doBeforeRequest(final String remoteAddr, final RemotingCommand request);


    public void doAfterResponse(final String remoteAddr, final RemotingCommand request,
            final RemotingCommand response);
}

发送消息拦截可实现统一处理:

public interface SendMessageHook {
    String hookName();

    void sendMessageBefore(final SendMessageContext context);

    void sendMessageAfter(final SendMessageContext context);
}

消费消息拦截:

public interface ConsumeMessageHook {
    String hookName();

    void consumeMessageBefore(final ConsumeMessageContext context);

    void consumeMessageAfter(final ConsumeMessageContext context);
}

消息过滤:

public interface FilterMessageHook {
    public String hookName();


    public void filterMessage(final FilterMessageContext context);
}

此外,同步异步发送消息都是基于netty进行的实现.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值