深入浅出 JMS(三) - ActiveMQ 消息传输

一、消息协商器(Message Broker)

broke:消息的交换器,就是对消息进行管理的容器。ActiveMQ 可以创建多个 Broker,客户端与 ActiveMQ 交互,实际上都是与 ActiveMQ 中的 Broker 交互,Broker 配置在 ${MQ_HOME}/conf/activemq.xml。

二、连接器(Connectors)

(一)传输连接器(transportConnectors)

transportConnectors 连接器:就是建立broker与消息生产者、消息消费者之间的交互。

传输连接器常用的协议:

在 ActiveMQ 中常用的连接协议:tcp、udp、nio、ssl、http、https、vm。如果使用 ssl 协议需要配置证书,使用 http 或者 https 需要使用httpclient 来发送接收消息。

(1)TCP 默认的协议

  1. 使用 TCP 协议的好处:

    • 高效的:该协议连接使用了 OpenWire 协议,通过把消息转换成字节流,性能非常好
    • 可用性:TCP 是使用非常广泛的网络协议,基本上所有的平台都支持
  2. TCP 连接的 URI 形式:tcp://hostname:port?key=value&key=value,后面的参数选填

  3. TCP 配置示例 conf/activemq.xml:

    <transportConnectors>
    <!--activemq 的默认连接 tcp-->
    <transportConnector name="openwire" uri="tcp://0.0.0.0:61616"/>
    </transportConnectors>

(2)NIO

  1. NIO 协议和 TCP 协议类似,但 NIO 更侧重于底层的访问操作。它允许开发人员对同一资源可有更多的 client 调用和服务端有更多的负载。

  2. 适合使用 NIO 协议的场景:

      

    • 可能有大量的 Client 去链接到 Broker 上。一般情况下,大量的 Client 去连接 Broker 是被操作系统的线程数所限制的。因此, NIO 的实现比 TCP 需要更少的线程去运行,所以建议使用 NIO 协议。
    • 可能对于 Broker 有一个很迟钝的网络传输。NIO 比 TCP 提供更好的性能。
  3. NIO 连接的 URI 形式:nio://hostname:port?key=value,后面的参数选填。

  4. NIO 配置实例 conf/activemq.xml:

    <transportConnectors>
    <!-- 设置一个NIO的连接-->
    <transportConnector name="nio" uri="nio://0.0.0.0:61617"/>
    </transportConnectors>

(3)UDP

  1. UDP 和 TCP 的区别

    • TCP 是一个原始流的传递协议,意味着数据包是有保证的,换句话说,数据包是不会被复制和丢失的。UDP,它是不会保证数据包的传递的可靠性。
    • TCP 是被用在稳定可靠的场景中使用的;UDP 通常用在快速数据传递和不怕数据丢失的场景中,还有 ActiveMQ 通过防火墙时,只能用 UDP。
  2. UDP 连接的 URI 形式:udp://hostname:port?key=value

  3. 配置实例 conf/activemq.xml:

    <transportConnectors>
    <transportConnector name="udp" uri="udp://localhost:61618"/>
    </transportConnectors>

(4)、SSL

底层是 TCP 协议,但是对传输数据进行了加密。

  1. 适用场景:MQ 暴露在外网,要求客户端与 broker 之间通讯

  2. SSL 的连接的 URI 形式:ssl://hostname:port?key=value

  3. 配置实例 conf/activemq.xml:

    <transportConnectors>
    <transportConnector name="ssl" uri="ssl://localhost:61619"/>
    </transportConnectors>

使用步骤:

  1. 创建 SSL 协议:

  2. 配置 Broker SSL 协议 conf/activemq.xml:

    <sslContext>
    <sslContext keyStore="F:/beifeng/apache-activemq-5.6.0/conf/mybroker.ks"
    keyStorePassword="test123" />
    </sslContext>
  3. 配置客户端 SSL 协议:

(5)HTTP、HTTPS

  1. 通过 jetty 容器来接收 http 协议的 mq 消息。

  2. 用于只允许基本 HTTP 服务通过的网络环境。

  3. 通过 httpclient 来发送/接收消息,需要添加额外的 java 包 Httpclient、Xstream、activemq-optional。

  4. HTTP、HTTPS 的连接的 URI 形式:URI:http://hostname:port?key=value。

  5. 配置实例conf/activemq.xml:

    <transportConnectors>
    <transportConnector name="http" uri="http://localhost:8080"/>
    </transportConnectors>

配置 HTTPS 则需要在 jetty.xml 中配置相关证书 HTTPS=HTTP + SSL

(二)网络连接器(NetWorkConnectors)

NetWorkConnectors:用于 Broke 与 Broke 之间的交互 ,主要是 ActiveMq 集群部署时。

每天用心记录一点点。内容也许不重要,但习惯很重要!

深入浅出 JMS(三) - ActiveMQ 消息传输的更多相关文章

  1. 深入浅出 JMS(三) - ActiveMQ 安全机制

    深入浅出 JMS(三) - ActiveMQ 安全机制 一.认证 认证(Authentication):验证某个实体或者用户是否有权限访问受保护资源. MQ 提供两种插件用于权限认证: (一).Sim ...

  2. 深入浅出JMS(三)--ActiveMQ简单的HelloWorld实例

    第一篇博文深入浅出JMS(一)–JMS基本概念,我们介绍了JMS的两种消息模型:点对点和发布订阅模型,以及消息被消费的两个方式:同步和异步,JMS编程模型的对象,最后说了JMS的优点. 第二篇博文深入 ...

  3. 深入浅出 JMS(四) - ActiveMQ 消息存储

    深入浅出 JMS(四) - ActiveMQ 消息存储 一.消息的存储方式 ActiveMQ 支持 JMS 规范中的持久化消息与非持久化消息 持久化消息通常用于不管是否消费者在线,它们都会保证消息会被 ...

  4. 深入浅出 JMS(二) - ActiveMQ 入门指南

    深入浅出 JMS(二) - ActiveMQ 入门指南 上篇博文深入浅出 JMS(一) – JMS 基本概念,我们介绍了消息通信的规范JMS,这篇博文介绍一款开源的 JMS 具体实现-- Active ...

  5. 深入浅出JMS(二)--ActiveMQ简单介绍以及安装

    现实的企业中,对于消息通信的应用一直都非常的火热,而且在J2EE的企业应用中扮演着特殊的角色,所以对于它研究是非常有必要的. 上篇博文深入浅出JMS(一)–JMS基本概念,我们介绍了消息通信的规范JM ...

  6. 深入浅出JMS(四)--Spring和ActiveMQ整合的完整实例

    第一篇博文深入浅出JMS(一)–JMS基本概念,我们介绍了JMS的两种消息模型:点对点和发布订阅模型,以及消息被消费的两个方式:同步和异步,JMS编程模型的对象,最后说了JMS的优点. 第二篇博文深入 ...

  7. JMS学习三(ActiveMQ消息的可靠性)

    下面我们来学习一下消息接受确认和发送持久化消息.消息的过期.消息的选择器和消息的优先级. 一.消息接收确认 1.jms消息只有在被确认之后才认为成功消费了这条消息.消息的成功消费通常包括三个步骤:(1 ...

  8. 2015年12月10日 spring初级知识讲解(三)Spring消息之activeMQ消息队列

    基础 JMS消息 一.下载ActiveMQ并安装 地址:http://activemq.apache.org/ 最新版本:5.13.0 下载完后解压缩到本地硬盘中,解压目录中activemq-core ...

  9. JMS服务器ActiveMQ的初体验并持久化消息到MySQL数据库中

    JMS服务器ActiveMQ的初体验并持久化消息到MySQL数据库中 一.JMS的理解JMS(Java Message Service)是jcp组织02-03年定义了jsr914规范(http://j ...

随机推荐

  1. jsp 传多个值给后端

     页面上是这样 http://localhost:8080/smartcloset/getClothByCategory/1/11 直接用/分 后台是这样取的 @RequestMapping(valu ...

  2. phpmyadmin登录提示2005错误

    请修改phpMyAdmin\libraries\config.default.php 把 $cfg['Servers'][$i]['host'] 改成127.0.0.1

  3. leetcode66

    public class Solution { public int[] PlusOne(int[] digits) { ]; < ) { digits[digits.Length - ]++; ...

  4. maven - 配置强制从指定仓库拉取jar包

    从官方maven仓库拉取依赖,会超级慢.可配置settings.xml,强制从私服拉取 <mirrors> <mirror> <id>nexus-releases& ...

  5. delphi XE7 判断手机返回键

    Using the Android Device's Back Button To make your application handle when users press the Back but ...

  6. as3 程序域

    问题我要在应用程序中载入其他域的swf文件,并且允许它访问程序中的 ActionScript 解决办法使用flash.system.Security.allowDomain( ), flash.sys ...

  7. GPU寄存器相关

    1,shader model 3.0 只有256个常量寄存器,32个临时寄存器.对应dx9, opengl2.0, opengles2.0 2,shader model 4.0 有65536个寄存器, ...

  8. JSP共享javabean

    JavaBean是一种可重复使用,且跨平台的软件组件.JavaBean可分为两种:一种是有用户界面(UI)的javaBean:还有一种是没有用户界面,主要负责处理事务(如数据运算,操纵数据库)的jav ...

  9. Mysql update 一个表中自己的数据

    update  table ucf, table t2 set ucf.pcid = t2.pcid where t2.name = 'liming' and t2.gid= ucf.gid and ...

  10. print 不换行

    [print 不换行] 参考:http://zhidao.baidu.com/link?url=-qC2RyT5_GWzW_N-SyqJYgegVt2sSXwmMWGvHfk_4MjErhm_Pj23 ...