ActiveMQ学习笔记-08——ActiveMQ的传输协议

ActiveMQ学习笔记-08——ActiveMQ的传输协议

参考:【尚硅谷ActiveMQ教程(MQ消息中间件快速入门)

1. 各种协议介绍

  1. Transmission Control Protocol(TCP)(默认)
    • 默认的Broker配置,TCP的Client监听端口61616。
    • 在网络传输数据前,必须要序列化数据,消息说通过一个叫wire protocol的来序列化成字节流。
    • 默认情况下ActiveMQ把wire protocol叫做OpenWire,它的目的是促使网络上的效率和数据快速交互。
    • TCP连接的URI形式如:tcp://hostname:port?key=value&key=value,后面的参数上可选的
    • TCP传输的优点
      • TCP传输协议可靠性高,稳定性高
      • 高效性:字节流方式传递,效率很高
      • 高效性、可用性:应用广泛,支持任何平台
    • 具体参数配置查看官网:http://activemq.apache.org/tcp-transport-reference
  2. New I/O API Protocol(NIO)
    • NIO协议和TCP协议类似但NIO更侧重于底层的访问操作,它允许开发人员对同一资源可有更多的client调用和服务端游更多的负载。
    • 适合使用NIO的场景
      • 可能有大量的Client去连接到Broker上,一般情况下,大量的Client去连接Broker是被操作系统的线程所限制的。因此,NIO的实现比TCP需要更少的线程去运行,所以建议使用NIO协议
      • 可能对于Broker有一个很迟钝的网络传输,NIO比TCP提供更好的性能。
    • NIO连接的URI形式如:nio://hostname:port?key=value
    • 具体参数配置查看官网:http://activemq.apache.org/nio-transport-reference
  3. Advanced Message Queuing Protocol(AMQP)
    • 一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。
    • 具体参数配置查看官网:http://activemq.apache.org/amqp
  4. Streaming Text Orientated Message Protocol(stomp)
    • 是流文本定向消息协议,是一种为MOM(面向消息的中间件)设计的简单文本协议
    • 具体参数配置查看官网:http://activemq.apache.org/stomp
  5. Secure Sockets Layer Protocol(SSL)
  6. mqtt协议
  7. ws协议

2. 各种协议对比

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

3. NIO案例

  1. 修改配置文件activemq.xml

    <transportConnector name="nio" uri="nio://0.0.0.0:61618?trace=true"/>
    
  2. 修改生产者和消费者

    public static final String ACTIVEMQ_URL = "nio://127.0.0.1:61618";
    
  3. 修改某端口,支持多种协议

    <transportConnector name="auto+nio" uri="auto+nio://0.0.0.0:61608?maximumConnections=1000&amp;wireFormat.maxFramSize=104857600&amp;org.apache.activemq.transport.nio.SelectorManager.corePoolSize=20&amp;org.apache.activemq.transport.nio.SelectorManager.maximumPoolSize=50"/>
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值