ActiveMQ传输协议

1.ActiveMQ支持的client-broker通讯协议

  TCP、NIO、UDP、SSL、Http(s)、VM

  

 

   在配置文件中transportConnectors下,uri描述信息的头部都是采用协议名称

    描述amqp协议的监听端口时,采用的uri描述格式为"amqp://......"

    描述stomp协议的监听端口时,采用的uri描述格式为"stomp://......"

    唯独在进行openwire协议描述时,uri采用的是"tcp://......"。因为activeMQ中默认的消息协议就是openwire

  1)TCP协议

    这是默认的Broker配置,TCP的Client监听端口61616

    在网络传输数据前,必须要序列化数据,消息是通过一个叫wire protocol来序列化成字节流。

    默认情况下ActiveMQ把wire protocol叫做OpenWire,它的目的是促使网络上的效率和数据快速交互

    TCP连接的URI形式如:tcp://hostname:port?key=value*key=value,后面的参数是可选,参数设置参考官网的参数配置

    TCP传输的优点:

      TCP协议传输可靠性高,稳定性强

      高效性:字节流方式传递,效率很高

      有效性、可用性:应用广泛,支持任何平台

  2)NIO协议

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

    适合使用NIO协议的场景

      可能有大量的client去连接到Broker上,一般情况下,大量的Client去连接Broker是被操作系统的线程所限制的。因些,NIO的实现比TCP需要更少的线程去运行,所以建议使用NIO协议

      可能对于Broker有一个很迟钝的网络传输,NIO比TCP提供更好的性能

    NIO连接的URI形式:nio://hostname:port?key=value,参数设置参考官网的参数配置

<transportConnectors>
    <transportConnector name="nio" uri="nio://0.0.0.0:61618?trace=true">
</transportConnectors>

      如果不特别指定ActiveMQ的网络监听端口,那么这些端口都将使用BIO网络IO模型

      所以为了首先提高单节点的网络吞吐性能,我们需要明确指定Active的网络IO模型

      如下所示:URI格式头以”nio“开头,表示这个端口使用以TCP协议为基础的NIO网络IO模型

      

 

       这样配置,表示这个端口使用以TCP协议为基础的NIO网络IO模型。但这样的方式,只能使用这个端口支持Openwire协议

      怎么让这个端口支持NIO网络IO模型,又让它支持多个协议

        使用auto关键字

        使用”+“符号来为端口设置多种特性

        

  3)AMQP协议

    一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。

    基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制

    AMQP连接的URI形式:amqp://hostname:port?key=value,参数设置参考官网的参数配置

  4)STOMP协议

    是流文本定向消息协议,是一种为MOM(Message Oriented Middleware,面向消息的中间件)设计的简单文本协议
    AMQP连接的URI形式:stomp://hostname:port?key=value,参数设置参考官网的参数配置

  5)MQTT协议

    Message Queuing Telemerty Transport,消息队列遥测传输,是IBM开发的一个即时通讯协议,有可能成为物联网的重要组成部分

    该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和致动器的通信协议
    MQTT连接的URI形式:mqtt://hostname:port?key=value,参数设置参考官网的参数配置

  6)WS协议

    支持H5的websockets
    WS连接的URI形式:ws://hostname:port?key=value,参数设置参考官网的参数配置

  ActiveMQ支持的网络协议

 协议  描述
 TCP  默认的协议,性能相对可以
NIO  基于TCP协议之上的,进行了扩展和优化,具有更好的扩展性 
UDP  性能比TCP更好,但是不具有可靠性 
SSL  安全链接 
HTTP(S)  基于HTTP或者HTTPS 
VM  VM本身不是协议,当客户端和代理在同一个Java虚拟机中运行时,他们之间需要通行,但不想占用网络通道,而是直接通信,可以使用该方法 
posted @ 2021-03-01 10:56  学习大数据入门到放弃  阅读(352)  评论(0)    收藏  举报