ActiveMQ的传输协议

ActiveMQ支持的client-broker通讯协议

  • TCP
  • NIO
  • UDP
  • SSL
  • HTTP(S)
  • VM
    其中配置Transport Connector的文件在activeMQ安装目录的conf/activemq.xml中的标签之中
vim activemq.xml

在这里插入图片描述
在上文给出的配置信息中,
URI描述信息的头部都是用采用协议名称,:例如,
描述amqp协议的监听端口时,采用的URI描述格式为“amqp://……”
描述Stomp协议的监听端口时,采用的URI描述格式为“stomp://……”
唯独在进行openwire协议描述时,URI头却采用的“tcp://……”。这是因为ActiveMQ中默认的消息协议就是openwith

有哪些?

  • Transmission Control Protocol(TCP)默认

默认的Broker配置,TCP的Client监听端口61616
在网络传输数据前,必须要序列化数据,消息是通过一个叫wire protocol的来序列化成字节流。默认情况下ActiveMQ把wire protocol叫做OpenWire,它的目的是促使网络上的效率和数据快速交互。
TCP连接的URI格式:tcp://hostname:port?key=value&key=value,后面的参数是可选
TCP传输的优点
1.TCP协议传输可靠性高,稳定性强
2.高效性:字节流方式传递,效率很高
3.有效性、可用性:应用广泛,支持任何平台

  • New I/O API Protocol(NIO)

-NIO协议和TCP协议类似但NIO更侧重于底层的访问操作。它允许开发人员对统一资源可有更多的client调用和服务端有更多的负载。
-适合使用NIO协议的场景:
1.可能有大量的Client去连接到Broker上,一般情况下,大量的Client去连接Broker是被操作系统的线程所限制的。因此,NIO的实现比TCP需要更少的线程去允许,所以建议使用NIO协议
2.可能对于Broker有一个很迟钝的网络传输,NIO比TCP提供更好的性能。
-NIO连接的URI形式:nio//hostname:port?key=value

  • AMQP协议

一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。

  • stomp协议

是流文本定向消息协议,是一种为MOM(面向消息的中间件)设计的简单文本协议。

  • Secure Sockets Layer Protocol(SSL)
  • mqtt协议

是IBM开发的一个即时通讯协议,有可能成为物联网的重要组成部分。该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来做传感器和致动器的通信协议

  • ws协议

总结

协议描述
TCP默认的协议,性能相对可以
NIO基于TCP协议之上的,进行了扩展和优化,具有更好的扩展性
UDP性能比TCP更好,但是不具有可靠性
SSL安全连接
HTTP(S)基于HTTP或者HTTPS
VMVM本身不是协议,当客户端和代理在同一个Java虚拟机中运行时,他们之间需要通信,但不想占有网络通道,二是直接通信,可以使用该方法

NIO演示

修改配置文件activemq.xml

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

connections会出现nio
在这里插入图片描述
生产和消费两端协议修改

public static  final String ACTIVEMQ_URL="nio://192.168.10.100:61618";

NIO增强

上述NIO性能不错了,以“nio”开头,表示这个端口使用以TCP协议为基础的NIO网络io模型。但是这样的设置方式,只能使这个端口支持Openwire协议。怎么既让这个端口支持NIO网络IO模型,又让它支持多个协议呢?

解决

  • 使用auto关键字
  • 使用“+”符号来为端口设置多种特性
  • 如果我们既需要某一个端口支持NIO网络IO模型,又需要它支持多个协议
<transportConnector name="auto+nio" uri="auto+nio://0.0.0.0:61608?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600&amp;org.apache.activemq.transport.nio.SelectorManager.corePoolSize=20&amp;org.apache.activemq.transport.nio.SelectorManager.maximumPoolSize=50"/>

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值