码迷,mamicode.com
首页 > 其他好文 > 详细

ActiveMQ消息队列-简介

时间:2015-09-17 19:56:46      阅读:204      评论:0      收藏:0      [点我收藏+]

标签:

一、ActiveMQ是什么

ActiveMQ是一个消息中间件(Message-oriented middleware,MOM),实现JMS1.1规范,支持J2EE1.4以上,支持多种语言客户端(java,C,C++,AJAX等等),支持多种协议(http,https,ip多重广播,ssl协议,stomp协议,tcp协议,udp协议等)以及良好的spring支持。

二、ActiveMQ与RPC比较

1、都能实现系统之间解耦;

2、RPC是同步通信,ActiveMQ默认是异步通信,当然它也可支持同步通信;

3、ActiveMQ自身支撑简单的授权和认证方式,可通过配置properties文件来实现

4、可以以tomcat、jetty等服务器集成;

5、支持集群,管理控制简单。

三、安装ActiveMQ

可以进入官方网站下载对应版本的二进制包http://activemq.apache.org/download-archives.html),   在windows上解包,进入到apache-activemq-x.x.x\bin\activemq.bat运行ActiveMQ程序;如果是在Linux上,用命令tar zxvf activemq-x.x.x.tar.gz解包到一个目录就可以使用了。

ActiveMQ可能需要以下端口1099(JMX),61616(默认的TransportConnector)

windows查看监听端口:

netstat -an|find "61616"

Linux系统:

netstat -an|grep 61616

运行后可以打开web控制台:

http://localhost:8161/admin

如果能打开控制台页面,表示安装成功。

四、消息处理机制queue(p2p点对点模式)和topic(pub\sub发布订阅模式)


Topic Queue
概要 Publish Subscribe messaging 发布订阅消息 Point-to-Point 点对点
有无状态 topic数据默认不落地,是无状态的 Queue数据默认会在mq服务器上以文件形式保存,比如Active MQ一般保存在$AMQ_HOME\data\kr-store\data下面。也可以配置成DB存储
完整性保障 并不保证publisher发布的每条数据,Subscriber都能接受到 Queue保证每条数据都能被receiver接收
消息是否会丢失 一般来说publisher发布消息到某一个topic时,只有正在监听该topic地址的sub能够接收到消息;如果没有sub在监听,该topic就丢失了 Sender发送消息到目标Queue,receiver可以异步接收这个Queue上的消息。Queue上的消息如果暂时没有receiver来取,也不会丢失
消息发布接收策略 一对多的消息发布接收策略,监听同一个topic地址的多个sub都能收到publisher发送的消息。Sub接收完通知mq服务器 一对一的消息发布接收策略,一个sender发送的消息,只能有一个receiver接收。receiver接收完后,通知mq服务器已接收,mq服务器对queue里的消息采取删除或其他操作

 Topic和queue的最大区别在于topic是以广播的形式,通知所有在线监听的客户端有新的消息,没有监听的客户端将收不到消息;而queue则是以点对点的形式通知多个处于监听状态的客户端中的一个。

ActiveMQ消息队列-简介

标签:

原文地址:http://my.oschina.net/u/732520/blog/507798

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!