JMS学习十(ActiveMQ支持的传输协议)
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支持的传输协议)的更多相关文章
- ActiveMQ学习笔记(7)----ActiveMQ支持的传输协议
1. 连接到ActiveMQ Connector: Active提供的,用来实现连接通讯的功能,包括:client-to-broker,broker-to-broker.ActiveMQ允许客户端使用 ...
- 分布式-信息方式-ActiveMQ支持的传输协议和配置
ActiveMQ支持的传输协议和配置■ Connector: ActiveMQ提供的,用来实现连接通讯的功能.包括: client-to-broker ...
- ActiveMQ支持的传输协议
------------------------------------------------------ ActiveMQ支持的client-broker通讯协议有:TCP.NIO.UDP.SSL ...
- 消息中间件-ActiveMQ支持的消息协议
package com.study.mq.a1_example.helloworld.queue; import org.apache.activemq.ActiveMQConnectionFacto ...
- JMS学习(五)--ActiveMQ中的消息的持久化和非持久化 以及 持久订阅者 和 非持久订阅者之间的区别与联系
一,消息的持久化和非持久化 ①DeliveryMode 这是传输模式.ActiveMQ支持两种传输模式:持久传输和非持久传输(persistent and non-persistent deliver ...
- ActiveMQ支持的消息协议
ActiveMQ支持哪些协议 ActiveMQ支持多种协议传输和传输方式,允许客户端使用多种协议连接ActiveMQ支持的协议:AUTO,OpenWire,AMQP,Stomp,MQTT等Active ...
- 在window平台下,自己DIY编译OpenSSL,Libcurl ,来支持HTTPS传输协议
1 缘起 原来就了解些libcurl,一直没有机会在项目实际使用libcurl. 恰好最近一个云存储的项目,服务器使用openstack 恰好我负责现在的一个云存储SDK c++版本的开发中. 与 ...
- FastSocket学习笔记~制定自已的传输协议~续~制定基于FastSocket的协议
FastSocket这个东西上次我已经说过,它使用简单,功能强大,扩展灵活,目前在新浪的生产环境中已经被广泛使用,所以它的性能,安全等各方面我们绝对可以信赖,今天我们来说一个话题,和上一讲有关,这次我 ...
- FastSocket学习笔记~制定自已的传输协议
对于TCP或者UDP来说,它们作于传输层的协议,有着自己的标准,或者叫格式,在我们看TCP格式之前先了解一下计算机的基础知识,字节,它是计算机世界的一个小单位,也是我们可以理会到的,如一个utf-8英 ...
随机推荐
- Centos7单机安装Tableau2018.2
cd先将服务器防火墙80级8850端口打开 临时关闭SELinux/防火墙 setenforce 0 iptables -F 重点 重点 不能用root用户安装 不能用root用户安装 第一步先创建一 ...
- 手写数字识别 卷积神经网络 Pytorch框架实现
MNIST 手写数字识别 卷积神经网络 Pytorch框架 谨此纪念刚入门的我在卷积神经网络上面的摸爬滚打 说明 下面代码是使用pytorch来实现的LeNet,可以正常运行测试,自己添加了一些注释, ...
- noip2013day1-货车运输
题目描述 \(A\)国有\(n\)座城市,编号从 \(1\)到\(n\),城市之间有 \(m\) 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 \(q\) 辆货车在运输货物, 司机们想知 ...
- 【提高组NOIP2008】双栈排序 (twostack.pas/c/cpp)
[题目描述] Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一个元素压入栈S1 操作b 如果栈 ...
- Executor框架(转)
摘要: Executor作为灵活且强大的异步执行框架,其支持多种不同类型的任务执行策略,提供了一种标准的方法将任务的提交过程和执行过程解耦开发,基于生产者-消费者模式,其提交任务的线程相 ...
- Gogs官方帮助文档
环境要求 数据库(选择以下一项): MySQL:版本 >= 5.7 PostgreSQL MSSQL TiDB(实验性支持,使用 MySQL 协议连接) 或者 什么都不安装 直接使用 SQLit ...
- 微信小程序与内嵌webview之间来回跳转的几点总结,以及二维码的使用
截止到发稿小程序支持的功能,后续如果小程序更新在完善文稿. 1. 小程序可以内嵌组件跳转到h5页面,前提是在小程序后台配置相应的业务域名.新打开的h5页面会替代小程序组件内的其它组件,即为h5不能与小 ...
- JS实现hasClass addClass removeClass
// 判断class有无 function hasClass(ele, cls) { if (ele) { cls = cls || '' if (cls.replace(/\s/g, '').len ...
- C#使用反射机制获取类信息
1.用反射动态创建类实例,并调用其公有成员函数. //新建一个类库项目,增加一个GetSum方法. using System; namespace ClassLibrary1 { publi ...
- (转) ESB 企业服务总线基本内容概述
ESB全称为Enterprise Service Bus,即企业服务总线. 它是传统中间件技术与XML.Web服务等技术结合的产物(SOAP协议= HTTP协议+ XML数据格式). ESB提供了网络 ...