ActiveMQ提供了一种连接机制,这种连接机制使用传输连接器(TransportConnector)实现客户端与代理(client - to - broker)之间的通信。

网络连接器(networkconnection)实现代理与代理之间的通信。(broker-to- broker);

一、TransportConnector支持的协议

ActiveMQ常用协议:

协议-描述-example

TCP-默认的协议性能相对来说还是可以的-tcp://host:port

NIO-基于TCP协议进行了扩展和优化,具有更好的扩展性-NIO://host:port

UDP-相比TCP性能更好,但是没有tcp可靠-udp://host:port

SSL-安全连接-ssl://host:port

Http(s)-基于http或https的链接-http://host:port

注意使用ssl时要证书Http(s)要导入httpclient相关jar包

具体demo见官网:http://activemq.apache.org/uri-protocols.html

这些传送协议都是在activemq.xml中配置的:

TCP: activemq.xml配置文件配置

<broker>
...
<transportConnectors>
<transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
</<transportConnectors>
...
</broker>

TCP:客户端代码:

connectionFactory = new ActiveMQConnectionFactory("admin", "admin","tcp://127.0.0.1:61616");  

NIO:activemq.xml配置文件配置

<broker>
...
<transportConnectors>
<transportConnector name="nio" uri="nio://0.0.0.0:61616"/>
</<transportConnectors>
...
</broker>

NIO:客户端代码:

connectionFactory = new ActiveMQConnectionFactory("admin", "admin","nio://127.0.0.1:61616");

其他的也都一样!!!

二、newworkConnector(网络连接器)支持的协议

协议 描述      example

Static         静态协议           static://(tcp://ip:port)

Multicast    多点传送协议    uri="multicast://default"

这里先看两种协议,但支持的协议不只这两种。

1、静态网络连接器

静态网络连接器用于为一个网络中多个代理创建静态配置.这种配置协议使用了一种复合的URI--即包含其他URI的URI.

静态协议是broker to broker的连接。

静态网络连接器activemq.xml配置文件配置:可以和多个代理进行通信,进行数据的拉取。

<networkConnectors>
<networkConnector name="local network" uri="static://(tcp://ip:61616,tcp://ip2:61616)"/>
</networkConnectors>

实例:

代理A的配置

<broker xmlns="http://activemq.apache.org/schema/core" brokerName="BrokerA" dataDirectory="${activemq.data}">
<transportConnectors>
<transportConnector name="openwire" uri="tcp://127.0.0.1:61616" />
</transportConnectors>
</broker>

代理B的配置

<broker xmlns="http://activemq.apache.org/schema/core" brokerName="BrokerB" dataDirectory="${activemq.data}">
<transportConnectors>
<transportConnector name="openwire" uri="tcp://127.0.0.1:61617" />
</transportConnectors>
<networkConnectors>
<networkConnector uri="static:(tcp://127.0.0.1:61616)" />
</networkConnectors>
</broker>

代理B中配置了和代理A的网络连接,这样配置后就能实现数据从B代理到A代理的流动,即使客户端将消息发送到了B代理,但消息消费端访问A代理也能获取并消费发送到B代理的消息,这是因为他们之间配了网络连接即networkConnection,当消费端来消费消息的时候,A代理从B代理哪里吧消息读取过来在给访问A代理的消费者。

2、动态网络连接器

这种动态技术可以实现让客户端和代理之间,代理和代理之间实现动态识别,而不是配置静态的IP组。

多点传送协议,代理会广播自己的服务,也会定位其他代理。同理客户端可以通过多点协议来接收广播,识别出代理。

多址传送协议的URI语法如下: 
multicast://ipadaddress:port?key=value

<broker xmlns="http://activemq.apache.org/schema/core" brokerName="multicast" dataDirectory="${activemq.data}">
<networkConnectors>
<networkConnector name="default-nc" uri="multicast://default"/>
</networkConnectors> <transportConnectors>
<transportConnector name="openwire" uri="tcp://127.0.0.1:61616" discoveryUri="multicast://default"/>
</transportConnectors>
</broker>

在上面的例子中,使用群组名称"default"来替代具体的IP地址.上面的配置代码片段中有两个地方比较重要.首先,transport connector的discoveryUri属性用于暴露这个传输连接器的URI到名称为default的群组中.所有的希望查找可用代理的客户端都可以使用这个代理。

network connector的uri属性用于查找可用的代理并与之建立代理网络.这样配置后,代理就像客户端一样,使用多点传送协议来查找其他代理。 
移除discoveryUri属性,客户端就无法通过多点协议扫描到代理。

用多点传送协议的一个缺点是侦测是自动的.如果你不想把某个代理添加到群组中,你必须十分小心的设置。

客户端的自动侦测,通信语法是 
discovery:(discoveryAgentURI)?key=value
如connectionFactory = new ActiveMQConnectionFactory("admin", "admin","discovery:(multicast://default)");
将会自动侦测组名为default的代理。 
上面的配置 <transportConnectorname="openwire" uri="tcp://localhost:61616"discoveryUri="multicast://default"/>代理将会被侦测到。

三、Failover(失效重连协议)

failover:(uri1,...,uriN)?key=value 
或者failover:uri1,...,uriN,如 
failover:(tcp://primary:61616,tcp://secondary:61616)?randomize=false 
详细查看http://activemq.apache.org/failover-transport-reference.html 
默认情况是先随机选择一个连接器,如果该连接器无效,那么会选择下一个。 
失效转移连接器URI:是在客户端方面的协议,客户端在链接代理时需要保证链接的可用和可靠。实际上就算客户端只会连接一个代理,也应该使用failover配置通信协议,保证网络中断等问题时会自动重连。

失效重连协议是客户端方面的额协议,所以activemq.xml配置文件中就不用配置什么了……

实例:

connectionFactory = new ActiveMQConnectionFactory("admin", "admin","failover:(tcp://127.0.0.1:61616,tcp://127.0.0.1:61617)?randomize=false&priorityBackup=true");  

首先连接61616 如果连接失败则连接61617

设置连接优先级:

failover:(tcp://local1:61616,tcp://local2:61616,tcp://remote:61616)?randomize=false&priorityBackup=true&priorityURIs=tcp://local1:61616,tcp://local2:61616  

其他配置见管网.

总结:

1、传输连接器:主要是用户客户端到消息服务端的连接,在activemq的传输连接器<TransportConnector> 中配置,同时客户端ConnectionFactory中也配置同样的协议!

2、网络连接器:主要是代理和代理之间通信的,通信的目的就是数据的拉取!

3、失效重连协议:这个协议是客户端的协议,在创建ConnectionFactory 对象的时候可以指定多个JMS服务,并且可以指定优先级,这样就会按照优先级进行连接,如果优先级最高的能连上则连接他如果优先级最高的机器连接不上则连接连接优先级次高的以此类推。

参考文章:http://blog.csdn.net/vtopqx/article/details/51787717

JMS学习十(ActiveMQ支持的传输协议)的更多相关文章

  1. ActiveMQ学习笔记(7)----ActiveMQ支持的传输协议

    1. 连接到ActiveMQ Connector: Active提供的,用来实现连接通讯的功能,包括:client-to-broker,broker-to-broker.ActiveMQ允许客户端使用 ...

  2. 分布式-信息方式-ActiveMQ支持的传输协议和配置

                             ActiveMQ支持的传输协议和配置■ Connector: ActiveMQ提供的,用来实现连接通讯的功能.包括: client-to-broker ...

  3. ActiveMQ支持的传输协议

    ------------------------------------------------------ ActiveMQ支持的client-broker通讯协议有:TCP.NIO.UDP.SSL ...

  4. 消息中间件-ActiveMQ支持的消息协议

    package com.study.mq.a1_example.helloworld.queue; import org.apache.activemq.ActiveMQConnectionFacto ...

  5. JMS学习(五)--ActiveMQ中的消息的持久化和非持久化 以及 持久订阅者 和 非持久订阅者之间的区别与联系

    一,消息的持久化和非持久化 ①DeliveryMode 这是传输模式.ActiveMQ支持两种传输模式:持久传输和非持久传输(persistent and non-persistent deliver ...

  6. ActiveMQ支持的消息协议

    ActiveMQ支持哪些协议 ActiveMQ支持多种协议传输和传输方式,允许客户端使用多种协议连接ActiveMQ支持的协议:AUTO,OpenWire,AMQP,Stomp,MQTT等Active ...

  7. 在window平台下,自己DIY编译OpenSSL,Libcurl ,来支持HTTPS传输协议

    1 缘起 原来就了解些libcurl,一直没有机会在项目实际使用libcurl.   恰好最近一个云存储的项目,服务器使用openstack 恰好我负责现在的一个云存储SDK c++版本的开发中. 与 ...

  8. FastSocket学习笔记~制定自已的传输协议~续~制定基于FastSocket的协议

    FastSocket这个东西上次我已经说过,它使用简单,功能强大,扩展灵活,目前在新浪的生产环境中已经被广泛使用,所以它的性能,安全等各方面我们绝对可以信赖,今天我们来说一个话题,和上一讲有关,这次我 ...

  9. FastSocket学习笔记~制定自已的传输协议

    对于TCP或者UDP来说,它们作于传输层的协议,有着自己的标准,或者叫格式,在我们看TCP格式之前先了解一下计算机的基础知识,字节,它是计算机世界的一个小单位,也是我们可以理会到的,如一个utf-8英 ...

随机推荐

  1. Nginx配置与使用

    一.简单介绍 由俄罗斯程序员IgorSysoev研发,2004年开源公布,特点是:内存cpu占用低,并发能力强,稳定,配置示例,反向代理:互联网企业 70%以上公司都在使用 nginx: 二.安装 1 ...

  2. mysql中char,varchar与text类型的区别

      关于char,varchar与text平时没有太在意,一般来说,可能现在大家都是用varchar.但是当要存储的内容比较大时,究竟是选择varchar还是text呢?不知道...... text  ...

  3. javaweb:Response/Request的概述 (转发、重定向、get/post)转

    请求响应流程图 1]response 1   response概述 response是Servlet.service方法的一个参数,类型为javax.servlet.http.HttpServletR ...

  4. 2019牛客暑期多校训练营(第九场) - B - Quadratic equation - 二次剩余

    https://ac.nowcoder.com/acm/contest/889/B 假如我们能够求出 \(x-y\) 在模p意义的值,那么就可以和 \(x+y\) 联立解出来了. 由于 \((x-y) ...

  5. mysql-5.7.25安装以及使用

    1. wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz 2. ...

  6. ivew组件上传图片文件的功能:

    解决的问题: 1.使用view的<Upload>组件实现图片文件的上传. 2.<Upload>组件action请求地址无法到自己写的后台. 3.前台base64的图片展示. 4 ...

  7. vue history模式 ios微信分享坑

    vue history模式 ios微信分享坑 问题分析:因为苹果分享会是调取签名失败是因为:苹果在微信中浏览器机制和安卓不同,有IOS缓存问题,和IOS对单页面的优化问题,通俗点说安卓进行页面跳转分享 ...

  8. DEV第三方控件的GalleryControl控件

    1.获取选中的图片 List<GalleryItem> lstArray = gclImage.Gallery.GetCheckedItems(); 2.滚动到GalleryControl ...

  9. 去除多余的Merge branch提交

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/xuexingyang/article/d ...

  10. Linux学习--第十三天--日志、系统运行级别、grub加密

    日志 rsyslogd取代了syslogd. /var/log/cron #定时任务相关日志 /var/log/cups #打印信息相关日志 /var/log/dmesg #开机内核自检相关日志,dm ...