Azure上搭建ActiveMQ集群-基于ZooKeeper配置ActiveMQ高可用性集群
ActiveMQ从5.9.0版本开始,集群实现方式取消了传统的Master-Slave方式,增加了基于ZooKeeper+LevelDB的实现方式。
本文主要介绍了在Windows环境下配置基于ZooKeeper的ActiveMQ高可用性集群,集群实现了主备功能,实现了单点故障时的高可用性,并不涉及负载均衡技术。
从整体上看,整个安装配置过程主要有以下几个步骤:
1. Windows Server环境搭建、端口配置
2. Jre安装配置
3. Zookeeper安装配置
4. ActiveMQ安装配置
本文中我们搭建3个节点的Zookeeper和ActiveMQ集群,整体架构:

各种组件使用的是:
基于Windows Azure的Windows Server2012
JDK 1.7
ZooKeeper 3.4.6
ActiveMQ 5.12
一、 Windows Server环境搭建、端口配置
我们需要搭建3个Windows Server虚拟机,用作Zookeeper的三个节点以及消息服务器。
1. 创建Windows Server虚拟机(三个)
进入Windows Azure的管理控制台,选择New-Compute-Virtual Machine-From Gallery

选择Windows Server镜像,选择Windows Server2012 R2 DataCenter


配置以下开放的端口:

2. 配置端口说明

二、 JRE安装配置
ZooKeeper和ActiveMQ都依赖于Jdk,因此我们需要先安装配置JDK1.7
1. JDK下载
JDK的下载地址为:
http://download.oracle.com/otn/java/jdk/7u80-b15/jdk-7u80-windows-x64.exe?AuthParam=1446712677_06310dc4ac8a4e8664ae69cb80b6659a
2. JDK安装、配置环境变量
双击exe直接安装,依次下一步处理,注意,路径中不能包含汉字。


将JAVA_HOME加入到环境变量,并生效

环境变量CLASS_PATH:
.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;

三、 安装配置ZooKeeper
目前我们已经创建了三个Window Server 2012虚拟机

1. 在10.***.***.47上配置Zookeeper-1
主要配置Zoo.Cfg文件、新建Data文件夹和myid文件
zookeeper文件目录:

修改Conf中的zoo.cfg文件(将zoo_sample.cfg改名为zoo.cfg),

设置下Data文件夹的路径,例如:dataDir=C:\\zookeeper\\data
Data文件夹需要新建
设置ZooKeeper集群,这里我们用了3个节点,以下是集群配置:
server.1=10.***.***.47:2888:3888
server.2=10.***.***.27:2888:3888
server.3=10.***.***.51:2888:3888
在Data文件夹下新建MyID文件,MyID文件中的内容为当前Node的ID,例如1

2. 在10.***.***.27上配置Zookeeper-2
与配置Zookeeper-1相同,不同的是myid文件的内容:2
3. 在10.***.***.51上配置Zookeeper-3
与配置Zookeeper-1相同,不同的是myid文件的内容:3
4. 启动zookeeper
Windows下启动Zookeeper是执行bin目录下的zkServer.cmd文件,
依次启动三个虚拟机上的zookeeper:



四、 安装配置ActiveMQ集群
下载ActiveMQ,
http://mirror.bit.edu.cn/apache/activemq/5.12.0/apache-activemq-5.12.0-bin.tar.gz
将ActiveMQ拷贝到三个Windows虚拟机中。
1. 修改ActiveMQ配置
ActiveMQ的配置文件在Conf文件夹下的ActiveMQ.xml,我们主要修改两个地方:
BrokerName:三个节点的ActiveMQ的BrokerName必须一致,例如:teldbroker

persistenceAdaper:主要配置zkAddress(三个Zookeeper节点)和hostname,
hostname是本机的IP

在其他两个虚拟机上进行统一的配置,注意不同的虚拟机不同的hostname.
2. 启动ActiveMQ
在三台虚拟机上依次启动ActiveMQ:在bin目录执行:activemq start

3. 连接ActiveMQ
ActiveMQ在集群模式下的连接字符串是不同的:
failover:(tcp://42.***.***.90:61616,tcp://42.***.***.193:61616,tcp://42.***.***.140:61616)
ActiveMQ IConnection Demo:

五、 ActiveMQ集群高可用性测试
1. ActiveMQ集群切换
关闭当前正在提供服务的ActiveMQ Master节点,其他的Slave节点中选定其中一个自动提升为Master节点。程序可以正常连接MQ服务。
消息发送完备后,切换ActiveMQ节点,消息可以正常消费。
当前Master节点的Web Console可以访问。



2. ZooKeeper集群切换
ZooKeeper的一个Leader节点关闭后,其他的Follower节点会被选中一个提升为Leader节点。
ActiveMQ可以正常访问。


以上是在Azure云端搭建ActiveMQ集群,分析给大家。
周国庆
2019/3/14
Azure上搭建ActiveMQ集群-基于ZooKeeper配置ActiveMQ高可用性集群的更多相关文章
- 部署hadoop2.7.2 集群 基于zookeeper配置HDFS HA+Federation
转自:http://www.2cto.com/os/201605/510489.html hadoop1的核心组成是两部分,即HDFS和MapReduce.在hadoop2中变为HDFS和Yarn.新 ...
- Spark集群基于Zookeeper的HA搭建部署笔记(转)
原文链接:Spark集群基于Zookeeper的HA搭建部署笔记 1.环境介绍 (1)操作系统RHEL6.2-64 (2)两个节点:spark1(192.168.232.147),spark2(192 ...
- 微软.NET年芳15:我在Azure上搭建Photon服务器(C#.NET)
网上火热的“微软.NET年芳15”文章,我也得写点什么嘛,毕竟我还是现任的微软MVP. 摘录网上的“.NET 15周年”信息如下: 微软的 .NET 框架本周迎来了 15 岁生日..NET 的第一个版 ...
- 在Azure上搭建L2TP服务器
L2TP是常用的一种point-site的VPN.而目前在Azure上的VPN Gateway只支持IPsec和SSTP两种.如果客户需要L2TP服务器,需要自己在VM中搭建.本文将介绍如何在Azur ...
- eureka集群基于DNS配置方式
https://www.cnblogs.com/relinson/p/eureka_ha_use_dns.html 最近在研究spring cloud eureka集群配置的时候碰到问题:多台eu ...
- 基于zookeeper的activemq的主从集群配置
项目,要用到消息队列,这里采用activemq,相对使用简单点.这里重点是环境部署. 0. 服务器环境 RedHat710.90.7.210.90.7.1010.90.2.102 1. 下载安装zoo ...
- 【2】基于zookeeper,quartz,rocketMQ实现集群化定时系统
<一>项目结构图 (1)ZK协调分配 ===>集群中的每一个定时服务器与zookeeper交互,由集群中的master节点进行任务划分,并将划分结果分配给集群中的各个服务器节点. = ...
- 在Windows Azure上搭建SSTP VPN
在国内,VPN是用来干嘛的大家都懂的.很久之前我尝试用Azure的Virtual Network搞VPN结果惨败了.最近微博上有基友写了篇文章亲测可行,原文在这里.可惜是英文的.所以我的这篇文章仅仅是 ...
- Windows Azure上搭建SSTP VPN
一.服务器设置 首先,从0开始,你需要创建一个新的VM.我选择Windows Server 2012 R2,所有步骤和创建普通VM都一样,但最后在防火墙设置里一定要打开TCP 443端口: 创建完成后 ...
随机推荐
- JZOJ5431 捕老鼠
JZOJ 5341 Description 为了加快社会主义现代化,建设新农村,农夫约(Farmer Jo)决定给农庄里的仓库灭灭鼠.于是,猫被农夫约派去捕老鼠. 猫虽然擅长捕老鼠,但是老鼠们太健美了 ...
- css 制作翻页布局
代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...
- Java try-cath-finally异常
Java 内置异常类 Java 语言定义了一些异常类在 java.lang 标准包中. 标准运行时异常类的子类是最常见的异常类.由于 java.lang 包是默认加载到所有的 Java 程序的,所以大 ...
- (81)Wangdao.com第十六天_JavaScript 严格模式
严格模式 除了正常的运行模式,JavaScript 还有第二种运行模式:严格模式(strict mode).顾名思义,这种模式采用更加严格的 JavaScript 语法 同样的代码,在正常模式和严格模 ...
- Node.js_Buffer 缓冲区
Buffer 缓冲区 虽然 JavaScript 支持未操作,但是并没有 二进制数据 的原生 node 引入了 Buffer 类,用于操作二进制数据 是 V8 引擎的扩展,实际上是对内存的直接分配 每 ...
- Junit/idea Junit支持/Spring test之间的孽世纠葛
最近应老板要求,研究研究Spring测试相关的东西,力求搞一个方便使用的测试工具,对于一个Spring不熟Junit不懂的人这是一个很大的坑,扫了一边spring test文档没感觉有什么收获,spr ...
- 【C++】子序列匹配问题
/* 一个串的“子序列”(subsequence)是将这个串中的一些字符提取出来得到一个新串,并且不改变它们的相对位置关系.例如,串"XDoi","XianYu!&quo ...
- centos7设置静态IP地址
1.查看IP配置信息 ifconfig 如上图所示,我的em1网卡已配置好 2.编辑em1对应的配置文件,位于/etc/sysconfig/network-scripts/ifcfg-你的网卡名字 操 ...
- 千万不要随意在网上下载ojdbcjar包来使用,ORA-01461错误解决
我在登录项目时,点击某一按钮提示ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值,但是项目在我的同事那里可以完好运行.最后百度 发现问题所在: 数据库与客户端的JDBC驱动不匹配. ...
- ADB——命令大全
基本语法 基本语法 adb [-d|-e|-s <serialNumber>] <command> # serialNumber表示设备序列号,也可以是ip地址 # 如果只有一 ...