AcitveMQ
首先,说起ActiveMQ,就必须先聊聊JMS(Java Message Service)规范,也就是Java消息服务,它定义了Java中访问消息中间件的接口的规范。JMS只是接口,并没有给予实现,实现JMS接口的消息中间件称为 “JMS Provider”,目前知名的开源 MOM (Message Oriented Middleware,也就是消息中间件)系统包括Apache的ActiveMQ、RocketMQ、Kafka,以及RabbitMQ,可以说他们都 “基本遵循” 或 “参考” JMS规范,都有自己的特点和优势。
mq能解决什么问题:
异步:调用者无需等待
解耦:解决系统之间的耦合调用
削峰:抵御洪峰流量,保护核心业务
activemq的简单介绍:
activemq有两种模式,一种是queue模式,一种的topic模式。queue模式的消息默认是持久化的,被消费者消费完就没了,一个消息只能被一个消费者消费。topic是一种主题订阅模式,消费者需要先订阅一个topic,然后消息出现了才会发送给订阅者,如果没有订阅者,消息会被丢弃。
五种消息格式
typeMessage、StreamMessage、TextMessage、ObjectMessage、MapMessage
传输协议
activemq支持很多种的传输协议,默认是使用http协议,可以