ActiveMQ的动态网络链接
多播协议 multicast
ActiveMQ使用 Multicast协议将一个 Service和其他的 Broker的 Service连接起来,IP
multicast是一个被用于网络中传输数据到其它一组接收者的技术。 Ipmulticast传统的概念称
为组地址。组地址是ip地址在224.0.0.0到239.255.255.255之间的ip地址。 ActiveMQ broker使
用multicast协议去建立服务与远程的 broker的服务的网络链接
基本的格式配置
multicast: //ipadaddress: port?transportOptions
transportOptions如下
1: group:表示唯一的组名称,缺省值 default
2: minmumwireFormatVersion:被允许的最小的 wireformat版本,缺省为0
3: trace:是否追踪记录日志,默认fa1se
4: useLocalHost:表示本地机器的名称是否为 localhost,默认true
5: datagramSize:特定的数据大小,默认值4*1024
6: timeTolive:消息的生命周期,默认值-1
7:loopBackMode:是否启用 loopback模式,默认false
8: wireFormat:默认用 wireFormat命名
9: wireFormat.*;前缀是 wireFormat
配置示例
1:默认配置,请注意,默认情况下是不可靠的多播,数据包可能会丢失
multicast://default
2.特定的ip和端口
multicast://224.1.2.3:6255
3:特定的ip和端口以及组名
multicast://224.1.2.3: 6255?group=mygroupname
Activemq使用multicast协议的配置格式如下

<broker xmlns="http://activemg.apacheorg/schema/core" brokerName="multicast"
dataDirectory="${activemq.base)/ data">
<networkConnectors>
<neworkConnector name="default-nc" uri="multicast: //default" />
</networkConnectors>
<transportConnectors>
<transportConnector name="openwire" uri="tcp://localhost: 61616"
discoveryUri="multicast: //default" />
</transportConnectors>
</broker>
上面的配置说明
1: uri=“multicast:// default”中的 default是 activemq默认的ip,默认动态的寻找地址
2:“ discoveryUri”是指在 transport中用multicast的 default的地址传递
3:“uri”指动态寻找可利用的地址
4:如何防止自动的寻找地址?
(1)名称为 openwire的 transport,移除 discoveryUri="multicast://default"即可。传输链接用
默认的名称 openwire来配置 broker的tcp多点链接,这将允许其它 broker能够自动发现和链接到
可用的 broker中。
(2)名称为“ default-nc”的 networkConnector,注释掉或者删除即可。
ActiveMQ默认的 networkConnector基于 multicast协议的链接的默认名称是 default-nc,
而且自动的去发现其他 broker,去停止这种行为,只需要注销或者删除掉 default-nc网络链接
(3)使 brokerName的名字唯一,可以唯一识别 Broker的实例,默认是 localhost
Multicast协议和普通的tcp协议
它们是差不多的,不同的是Multicast能够自动的发现其他 broker,从而替代了使用
static功能列表 brokers。用 multicast协议可以在网络中频繁的添加和删除ip不会有影响
multicast协议的好处是:能够适应动态变化的地址。
缺点:自动的链接地址和过度的销耗网络资源。
Discovery协议
Discovery是在 multicast协议的功能上定义的。功能类似与 failover功能。它将动
态的发现multicast协议的 broker的链接并且随机的链接其中一个broker
基本配置格式如下:
discovery: (discoveryAgent URI)?transportOptions
transportations如下:
1: econnectDelay:再次寻址等待时间,缺省值10
2: initial Reconnect Delay:初始化设定再次寻址等待时间,缺省值10
3: maxReconnectDelay:最大寻址等待时间,缺省值3000
4: useExponential Backoff:是否尝试 Backoff重链接,默认是true
5: backOffMultiplier:尝试 Backoff的次数,默认是2
6: maxReconnectAttempt s:如果异常,最大的重新链接个数,默认是0
7: group:组唯一的地址,默认是 default
示例:
discovery: (multicast: //default)?initialReconnectDelay=100
Discovery协议的配置示例
<broker name="foo">
<transportConnectors>
<transport Connector uri="tcp: //localhost: 0" discoveryUri="multicast: //default"/>
</transportConnectors>
</broker>
Peer协议
ActiveMQ提出了 peer transport connector以让你更加容易的去嵌入 broker中网络
中。它将创建一个优于VM链接的p2p网络链接。默认格式如下:
peer: //peergroup /brokerName? key=value
Peer协议基本使用
当我们启动了用peer协议时,应用将自动的启动内嵌 broker,也将会自动的去配置
其它 broker来建立链接,当然了,前提是必须属于一个组。配置如下:
peer: //groupa/broker? persistent=false
另外,生产者和消费者都各自链接到嵌入到自己应用的 broker,并且在在本地的同
个组名中相互访问数据。

Peer协议的基本原理示意图
图8-1

在本地机器断网的情况下,本地的client访问本地 brokerA将任然正常。在断网的情
况下发送消息到本地 brokerA,然后网路链接正常后,所有的消息将重新发送并链接到
brokerB
Fanout协议
Fanout协议是同时链接多个 broker,默认的格式如下:
fanout: (fanoutURI)?key=value
示例: fanout: (static: (tcp: //host1: 61616, tcp: //host2: 61616, tcp: //host3: 61616))
表示client将试图链接到三个 static列表中定义的三个URI
Fanout协议的配置方式如下:
fanout:(discoveryURI?transportOptions
transportOptions如下:
1: initialReconnectdelay:重新链接的等待时间,默认是10
2: maxReconnectDelay:最大重新链接的等待时间,默认是30000
3: useExponentialBack0ff:是否尝试Back0ff重链接,默认是true
4: backOffMultiplier:尝试 Backoff的次数,默认是2
5: maxReconnectAttempts:如果异常,最大的重新链接个数,默认是0
6: fanOutQueues:是否将 topic消息转换 queue消息,默认 false
7: minAckCount: Broker链接的最小数,默认是2
配置示例:
fanout:(static:(tcp: //localhost: 61616, tcp: //remotehost: 61616))?initialReconne
ctDelay=100
特别提醒
Activemq不推荐使 Consumer使用 fanout协议。当 Provider发送消息到多个 broker中,
测试 Consumer可能收到重复的消息

分布式-信息方式-ActiveMQ的动态网络链接的更多相关文章

  1. 分布式-信息方式-ActiveMQ的集群

    ActiveMQ的集群Queue consumer clusters              ActiveMQ支持 Consumer对消息高可靠性的负载平衡消费,如果一个 Consumer死掉,该消 ...

  2. 分布式-信息方式-ActiveMQ静态网络连接的容错

    容错的链接Failover Protocol 前面讲述的都是client配置链接到指定的 broker上.但是,如果 Broker的链接失败怎么办呢?此时, Client有两个选项:要么立刻死掉,要么 ...

  3. 分布式-信息方式-ActiveMQ的Message dispatch高级特性之(指针) Message cursors

    Message dispatch高级特性之 Message cursors概述            ActiveMQ发送持久消息的典型处现方式是:当消息的消费者准备就绪时,消息发送系统把存储的 消息 ...

  4. 分布式-信息方式-ActiveMQ的Destination高级特性3

    虚拟destination用来创建逻辑destination,客户端可以通过它来生产和消费消息,它会把消息映射到物理destination. ActiveMQ支持2种方式: 1:虚拟主题(Virtua ...

  5. 分布式-信息方式-ActiveMQ的Destination高级特性1

    ActiveMQ的Destination高级特性 Destination高级特性----->Composite Destinations 组合队列Composite Destinations : ...

  6. 分布式-信息方式-ActiveMQ的静态网络连接

                           ActiveMQ的静态网络连接 在一台服务器上启动多个Broker步骤如下:1:把整个conf文件夹复制一份,比如叫做conf22:修改里面的 activ ...

  7. 分布式-信息方式-ActiveMQ的消息存储持久化

    ActiveMQ的消息存储持久化■概述ActiveMQ不仅支持 persistent和 non-persistent两种方式,还支持消息的恢复( recovery)方式PTPQueue的存储是很简单的 ...

  8. 分布式-信息方式-ActiveMQ基础

    ActiveMQ简介 ActiveMQ是什么ActiveMQ是Apache推出的,一款开源全支持JMS.1和J2EE1.4范的JMS Provider实现的信息中间件.(message oriente ...

  9. 分布式-信息方式-ActiveMQ的Destination高级特性2

    使用filtered destinations,在xml配置如下: <destinationInterceptors> <virtualDestinationInterceptor& ...

随机推荐

  1. python中进程的几种创建方式

    在新创建的子进程中,会把父进程的所有信息复制一份,它们之间的数据互不影响. 使用os.fork()创建 该方式只能用于Unix/Linux操作系统中,在windows不能用. import os # ...

  2. button标签与input type=button标签使用的差异

    button标签和input type=button标签都是html文档中用来表示按钮属性的元素,不过他们在布局和实际使用功能中存在一些差异. 下面将项目中遇到的一些总结如下: 1.属性和布局差异. ...

  3. luogu题解 P1707 【刷题比赛】矩阵加速递推

    题目链接: https://www.luogu.org/problemnew/show/P1707 分析: 洛谷的一道原创题,对于练习矩阵加速递推非常不错. 首先我们看一下递推式: \(a[k+2]= ...

  4. DES加密解密 MD5加密解密

    #region MD5 加密 /// <summary> /// MD5加密静态方法 /// </summary> /// <param name="Encry ...

  5. Win7下配置IIS服务器以及网站发布

    本文摘至于:http://heavengate.blog.163.com/blog/static/202381053201391111512986/ 1.vsual Studio 2010下利用本地I ...

  6. 转载: java获取json数组格式中的值

    转自:https://www.cnblogs.com/kkxwze/p/11134846.html   第一种方法: String str = "{'array':[{'id':5,'nam ...

  7. 颜色框架Hue使用方法

    Hue地址 如果有疑问或者想探讨iOS开发相关的技术,十分欢迎. 1. cocoapods安装Hue pod "Hue" 2. 导入框架 import Hue 3. 将十六进制数字 ...

  8. python之multiprocessing多进程

    multiprocessing 充分利用cpu多核一般情况下cpu密集使用进程池,IO密集使用线程池.python下想要充分利用多核CPU,就用多进程. Process 类Process 类用来描述一 ...

  9. QQ恶搞 - 让艾特你的人语无伦次

    效果图: 实现过程: 代码: ‮ 将上面的代码复制添加到你的群名片后面即可. 原理解析: 这个代码是一个Unicode控制字符 - RLO,它可以控制在它后面的所有文本都已倒序的方式显示.在qq群艾特 ...

  10. Delphi 处理异常情况