ActiveMQ详细入门教程系列(一),看看最新BTA大厂的Java程序员的招聘技术标准

本文详细介绍了ActiveMQ在解耦、冗余、扩展性、可恢复性、顺序保证、过载保护和数据流处理等方面的核心优势。讨论了消息队列如何提高系统的稳定性和可靠性,并比较了ActiveMQ与其他主流消息队列的特性。此外,还提供了ActiveMQ的安装启动、Web控制台使用及Java开发示例。
摘要由CSDN通过智能技术生成
2.3 解耦

降低工程间的强依赖程度,针对异构系统进行适配。在项目启动之初来预测将来项目会碰到什么需求,是极其困难的。通过消息系统在处理过程中间插入了一个隐含的、基于数据的接口层,两边的处理过程都要实现这一接口,当应用发生变化时,可以独立的扩展或修改两边的处理过程,只要确保它们遵守同样的接口约束。

在这里插入图片描述

2.4 冗余

有些情况下,处理数据的过程会失败。除非数据被持久化,否则将造成丢失。消息队列把数据进行持久化直到它们已经被完全处理,通过这一方式规避了数据丢失风险。许多消息队列所采用的”插入-获取-删除”范式中,在把一个消息从队列中删除之前,需要你的处理系统明确的指出该消息已经被处理完毕,从而确保你的数据被安全的保存直到你使用完毕。

2.5 扩展性

因为消息队列解耦了你的处理过程,所以增大消息入队和处理的频率是很容易的,只要另外增加处理过程即可。不需要改变代码、不需要调节参数。便于分布式扩容。

2.6 可恢复性

系统的一部分组件失效时,不会影响到整个系统。消息队列降低了进程间的耦合度,所以即使一个处理消息的进程挂掉,加入队列中的消息仍然可以在系统恢复后被处理。

2.7 顺序保证

在大多使用场景下,数据处理的顺序都很重要。大部分消息队列本来就是排序的,并且能保证数据会按照特定的顺序来处理。

2.8 过载保护

在访问量剧增的情况下,应用仍然需要继续发挥作用,但是这样的突发流量无法提取预知;如果以为了能处理这类瞬间峰值访问为标准来投入资源随时待命无疑是巨大的浪费。使用消息队列能够使关键组件顶住突发的访问压力,而不会因为突发的超负荷的请求而完全崩溃。

2.9 数据流处理

分布式系统产生的海量数据流,如:业务日志、监控数据、用户行为等,针对这些数据流进行实时或批量采集汇总,然后进行大数据分析是当前互联网的必备技术,通过消息队列完成此类数据收集是最好的选择。

三、常用消息队列(ActiveMQ、RabbitMQ、RocketMQ、Kafka)比较


| 特性MQ | ActiveMQ | RabbitMQ | RocketMQ | Kafka |

| — | — | — | — | — |

| 生产者消费者模式 | 支持 | 支持 | 支持 | 支持 |

| 发布订阅模式 | 支持 | 支持 | 支持 | 支持 |

| 请求回应模式 | 支持 | 支持 | 不支持 | 不支持 |

| Api完备性 | 高 | 高 | 高 | 高 |

| 多语言支持 | 支持 | 支持 | java | 支持 |

| 单机吞吐量 | 万级 | 万级 | 万级 | 十万级 |

| 消息延迟 | 无 | 微秒级 | 毫秒级 | 毫秒级 |

| 可用性 | 高(主从) | 高(主从) | 非常高(分布式) | 非常高(分布式) |

| 消息丢失 | 低 | 低 | 理论上不会丢失 | 理论上不会丢失 |

| 文档的完备性 | 高 | 高 | 高 | 高 |

| 提供快速入门 | 有 | 有 | 有 | 有 |

|

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值