Activemq集群搭建
集群搭建
一:静态网络集群
1.简介
 当ActiveMQ面对大量消息存储和大量Client交互时,性能消耗将会达到单个broker极限,此时我们需要对ActiveMQ进行水平扩展。ActiveMQ提供了“network”机制,可以把多个broker实例“串联”一起,形成“Forward Bridge”模型(转发桥)。这些Broker通过有向网络(networker Connector)链接在一起,组成broker集群,任何一个Borker都可以与Client数据交互,消息也将在Broker网络中“流动”直到被消费,之所以“流动”,因为“producer”和“consumer”会与不同的broker建立链接,我们认为“转发桥”架构模式是“较大”集群数据的解决方案。
2.拓扑图
3.配置示例
在activemq.xml配置文件中加入
<beans
	<networkConnectors>
   		<networkConnector   uri="static:(tcp://172.22.30.17:61616,tcp://172.22.30.18:61616)" duplex="true"/>
	</networkConnectors>
<\beans
- url 对端mq的连接地址,如果有多台,以","为分隔符
- duplex true为双向订阅,两台mq之间互为消费者和生产者,如果为false,即配置主机为消费者,远端主机为生产者
二:主从集群
1.简介
 在master-slave模式中,消息将会在多个broker上备份,即集群中每个broker上消息都一样,在故障转移时不会发生消息丢失的问题(持久化消息)。
2.拓扑图
目前mq支持三种持久化方式,如下:
- kahadb:以本地的数据库形式存储,速度没有AMQ快,扩展性好,目前mq默认的持久化方式。
- AMQ:文件存储方式,写入速度快和容易恢复,默认文件大小为32M,5.3版本以前默认支持。
- JDBC:使用外置数据库的形式存储消息。
特性对比:
- AMQ/kahadb:读写性能一般
- jdbc:受限于数据库性能,也比较一般
- zookeeper:性能比较好
3.配置示例
修改activemq.xml文件,更改kahadb持久化方式为mysql
修改activemq.xml文件,更改kahadb持久化方式为mysql
        <persistenceAdapter>
            <jdbcPersistenceAdapter  dataDirectory="${activemq.base}/data" dataSource="#mysql-ds" useDatabaseLock="true"/>
            <!--
            <kahaDB directory="${activemq.data}/kahadb"/>
            -->
        </persistenceAdapter>
修改activemq,在后添加数据库连接信息
<bean id="mysql-ds" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://192.168.30.130:3306/activemq?relaxAutoCommit=true"/>
        <property name="username" value="root"/>
        <property name="password" value="p3temp_S"/>
        <property name="poolPreparedStatements" value="true"/>
</bean>
4.切换说明
- 当master启动后,会自动在activemq中创建三个表 - ACTIVEMQ_ACKS 为第三张表的外键连接
 ACTIVEMQ_LOCK master锁定,保证只有一个master
 ACTIVEMQ_MSGS 存储消息
 
- 优先读取到db的ACTIVEMQ_LOCK的为master 
- 处于slave状态的Broker,服务端口(61616)和manage(6181)端口是没有启动的。 
- 处于slave状态的Broker,会定时去读取MySQL,如果发现已经被锁了,则继续等待 - 2018-01-03 11:10:53,698 | INFO | Failed to acquire lock. Sleeping for 1000 milli(s) before trying again... | org.apache.activemq.store.jdbc.DefaultDatabaseLocker | main
 2018-01-03 11:11:45,715 | INFO | Failed to acquire lock. Sleeping for 1000 milli(s) before trying again... | org.apache.activemq.store.jdbc.DefaultDatabaseLocker | main
 2018-01-03 11:12:37,735 | INFO | Failed to acquire lock. Sleeping for 1000 milli(s) before trying again... | org.apache.activemq.store.jdbc.DefaultDatabaseLocker | main
 2018-01-03 11:13:29,751 | INFO | Failed to acquire lock. Sleeping for 1000 milli(s) before trying again... | org.apache.activemq.store.jdbc.DefaultDatabaseLocker | main
 
三:客户端
1.连接url说明
failover:(tcp://local:61616,tcp://remote:61616)?randomize=false&priorityBackup=true
- failover:连接地址池为多个,以","号为分隔符,当其中一个失效后,会自动切换
- randomize:false关闭随机选择
- priorityBackup:当randomize为false时,pri为true时,会默认为第一个为优先
- timeout:超时时间
Activemq集群搭建的更多相关文章
- Zookeeper+ActiveMQ集群搭建
		搭建三台虚拟机安装centos7.要提前安装好jdk环境 1.环境准备,搭建三台虚拟机ip分别是 192.168.192.130 192.168.192.131 192.168.192.134 Zoo ... 
- activeMQ集群搭建及高可用
		三台服务器搭建如下的集群,达到了高可用.也同时达到了负载的目的: /****************************************************************** ... 
- activemq集群搭建Demo
		activemq5.14.5单节点安装Demo 第一步:创建集群目录 [root@node001 ~]# mkdir -p /usr/local/activemqCluster 复制单点至集群目录 [ ... 
- ActiveMQ集群简单测试+eclipse Zookeeper 插件 + 负载均衡
		ActiveMQ集群搭建好之后,接下来就该测试一下了. 一.先安装Zookeeper 的eclipse插件吧. 1. 打开 eclipse, Help -> Install New Softwa ... 
- Zookeeper3.4.10 + ActiveMQ-5.15.0 集群搭建
		网上的教程真的是凤毛麟角,就不想说啥了,一次一次把我带入坑. 好了关于Zookeeper的搭建已经说好了,本文说说基于Zookeeper的MQ集群. 第一步.将mq安装包上传到CentOS7,并解压 ... 
- Azure上搭建ActiveMQ集群-基于ZooKeeper配置ActiveMQ高可用性集群
		ActiveMQ从5.9.0版本开始,集群实现方式取消了传统的Master-Slave方式,增加了基于ZooKeeper+LevelDB的实现方式. 本文主要介绍了在Windows环境下配置基于Zoo ... 
- JAVAEE——宜立方商城08:Zookeeper+SolrCloud集群搭建、搜索功能切换到集群版、Activemq消息队列搭建与使用
		1. 学习计划 1.solr集群搭建 2.使用solrj管理solr集群 3.把搜索功能切换到集群版 4.添加商品同步索引库. a) Activemq b) 发送消息 c) 接收消息 2. 什么是So ... 
- 基于zookeeper+leveldb搭建activemq集群--转载
		原地址:http://www.open-open.com/lib/view/open1410569018211.html 自从activemq5.9.0开始,activemq的集群实现方式取消了传统的 ... 
- Centos7上搭建activemq集群和zookeeper集群
		Zookeeper集群的搭建 1.环境准备 Zookeeper版本:3.4.10. 三台服务器: IP 端口 通信端口 10.233.17.6 2181 2888,3888 10.233.17.7 2 ... 
随机推荐
- LogCook 一个简单实用的Android日志管理工具
			众所周知,日志的管理是软件系统很重要的一部分,千万不可忽略其重要性.完整的日志将会在系统维护中起着异常重要的作用,就好像磨刀不误砍柴工一样,日志就像对系统进行分析的工具,工具便捷了,对系统分析起来就能 ... 
- Mysql基础--表的操作
			1.表的基本概念 每一行代表一条唯一的记录,每一列代表记录中的一个字段. 2.创建表 例子: 3.查看表结构 (1)DESCRIBE语句查看表定义 语法: 例子: (2)SHOW CREATE TAB ... 
- J2SE-包装类
			目录 1 为什么提供包装类? 2 装箱和拆箱 3 包装类的4个特点 4 包装类类型 正文 1 为什么提供包装类? 1) 由于Java的基本数据类型功能简单,不具备面向对象的特性,实际使用时存在很多的不 ... 
- cinder块存储 后端采用lvm、nfs安装配置
			#cinder块存储 后端采用lvm.nfs安装配置 openstack pike 安装 目录汇总 http://www.cnblogs.com/elvi/p/7613861.html #cinder ... 
- java的基本知识导航
			java基本知识 备注:本次主要是思维导图,就是简单的说一下,只会扩展导图中的java关键字,其他以后再写 1.思维导图 2.java关键字 关键字 描述 abstract 抽象方法,抽象类的修饰符 ... 
- 了解web及网络基础
			了解web及网络基础 以下内容简单的说明了一下TCP/IP协议族中HTTP协议.DNS服务.IP协议的一些概念和关系.笔者只是对知识点进行了总结,仅供参考: ) 转载请注明出处:了解web及网络基础 ... 
- UWP Flyout浮动控件
			看见没,点击"Options"按钮,浮动出来一个界面,这个界面可以用xaml自定义. 如果要点击的控件又Flyout属性那么,可以直接按照下面用 <Button Conten ... 
- Postgres中表和元组的组织方式
			PG version 9.5.3 PG中四种堆文件: 普通堆 临时堆 序列堆 TOAST表 PageHeaderData长度为24(截图为8.4版本,20字节)个字节包含的内容如下: 空闲空间的起始和 ... 
- centos yum  install redis
			linux下yum安装redis以及使用 1.yum install redis --查看是否有redis yum 源 [root@localhost ~]# yum install r ... 
- Docker笔记四:Elasticsearch实例部署
			在运行或启动elasticsearch容器前,先在宿主机上执行 sysctl -w vm.max_map_count=262144: 解决" max virtual memory areas ... 
