AMQ学习笔记 - 14. 实践方案:基于ZooKeeper + ActiveMQ + replicatedLevelDB的主从部署

时间:2022-09-28 11:37:03

概述


基于ZooKeeper + ActiveMQ + replicatedLevelDB,在Windows平台的主从部署方案。
主从部署可以提供数据备份、容错[1]的功能,但是不能提供负载均衡的功能。
 
注:
  1. 容错:主服务器宕掉,再选出一台作为作为主服务器,来提供服务。

部署图


AMQ学习笔记 - 14. 实践方案:基于ZooKeeper + ActiveMQ + replicatedLevelDB的主从部署
 

简单说明

ActiveMQ提供了队列、本地持久化的功能,ZooKeeper提供了主从选举的功能。Producers将消息发送给主从队列体系[1],Consumers从主从队列体系中获取消息。
注:
[1] 主从队列体系 - 除Producers、Consumers之外的,由ZooKeeper + ActiveMQ + replicatedLevelDB组成的体系。

模拟环境


1.软件环境

  1. 操作系统 -  Windows7
  2. JDK - 1.7
  3. activemq - 5.13.2
    下载包:apache-activemq-5.13.2-bin.zip
  4. zookeeper - 3.4.8
    下载包:zookeeper-3.4.8.tar.gz

2.网络环境

  1. 机器1
    ip:192.168.74.55
    zookeeper port:2181
    activemq port:61616
  2. 机器2
    ip:192.168.74.26
    zookeeper port:2181
    activemq port:61616
  3. 机器3
    ip:192.168.74.25
    zookeeper port:2181
    activemq port:61616

实施


1.安装、配置、启动ZooKeeper

  1. 将zookeeper-3.4.8.tar.gz解压缩到合适的路径。
  2. 复制conf/zoo_sample.cfg为conf/zoo.cfg
  3. 在conf/zoo.cfg中指定dataDir、dataLogDir、各服务器及端口信息
     # The number of milliseconds of each tick
    tickTime=2000
    # The number of ticks that the initial
    # synchronization phase can take
    initLimit=10
    # The number of ticks that can pass between
    # sending a request and getting an acknowledgement
    syncLimit=5
    # the directory where the snapshot is stored.
    # do not use /tmp for storage, /tmp here is just
    # example sakes.
    # dataDir=/tmp/zookeeper
    dataDir=F:/temp/zookeeper-3.4.8/data
    dataLogDir=F:/temp/zookeeper-3.4.8/log
    server.1=192.168.74.55:2888:3888
    server.2=192.168.74.26:2888:3888
    server.3=192.168.74.25:2888:3888
    # the port at which the clients will connect
    clientPort=2181
    # the maximum number of client connections.
    # increase this if you need to handle more clients
    #maxClientCnxns=60
    #
    # Be sure to read the maintenance section of the
    # administrator guide before turning on autopurge.
    #
    # http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
    #
    # The number of snapshots to retain in dataDir
    #autopurge.snapRetainCount=3
    # Purge task interval in hours
    # Set to "0" to disable auto purge feature
    #autopurge.purgeInterval=1
    修改内容:
    1) 注释掉第12行
    2) 第13行,添加dataDir
    3) 第14行,添加dataLogDir
    4) 第15-17行,以server.A=B:C:D的形式指定三台服务器
       A - 数字,表示服务器的编号
       B - 服务器的ip
       C - 服务器与集群中的Leader服务器交换信息的端口
       D - 用来执行选举时服务器相互通信的端口(万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的 Leader)
  4. 新建myid文件
    在dataDir指定的路径下,新建myid文件,文件内容是当前服务器的编号(和conf/zoo.cfg中的server编号对应)。
    e.g. 192.168.74.55机器的内容为:1
  5. 启动
    先切换到zookeeper目录,再启动(可以尝试设置PATH)
     D:\tools\PowerCmd>E:
    E:\>cd E:\418备份区\工作任务\20160318_消息队列\zookeeper-3.4.8
    E:\418备份区\工作任务\20160318_消息队列\zookeeper-3.4.8>bin\zkServer.cmd

2.安装、配置、启动ActiveMQ

  1. 将apache-activemq-5.13.2-bin.zip加压缩到合适的目录。
  2. 修改conf/activemq.xml文件内容
    将默认的<persistenceAdapter>配置的内容注释掉,添加基于replicatedLevelDB的持久化配置:
     <!--
    <persistenceAdapter>
    <kahaDB directory="${activemq.data}/kahadb"/>
    </persistenceAdapter>
    -->
    <persistenceAdapter>
    <replicatedLevelDB
    directory="${activemq.data}/leveldb"
    replicas="3"
    bind="tcp://0.0.0.0:0"
    zkAddress="192.168.74.55:2181,192.168.74.26:2181,192.168.74.25:2181"
    hostname="192.168.74.55"
    sync="local_disk"
    zkPath="/activemq/leveldb-stores"
    />
    </persistenceAdapter>
    注意:
    1) zkAddress依次指定三台服务器的ip和ZooKeeper的监听端口
    2) hostname为每一台服务器的ip地址,三台服务器根据实际情况修改
  3. 启动ActiveMQ
    先切换到安装目录,再启动(可以尝试设置PATH)
     cd E:\418备份区\工作任务\20160318_消息队列\apache-activemq-5.13.2
    bin\activemq start

3.在客户端程序中指定brokerURL

 # use the following property to configure the default connector
java.naming.provider.url=failover:(tcp://192.168.74.55:61616,tcp://192.168.74.26:61616,tcp://192.168.74.25:61616)?initialReconnectDelay=1000
说明:
brokerURL以"failover:(tcp://ip-1:amq-port-1,tcp://ip-2:amq-port-2,tcp://ip-3:amq-port-3)"的形式配置,则客户端会尝试依次进行连接;失败则继续尝试连接下一个。引入ZooKeeper之后,只有被选定为主服务器那一台可以被连接。

相关补充


1.已知情况

  1. 超过一半的故障,则体系失效
    如果有2台ActiveMQ故障,则体系不再工作,且会阻塞客户端(同步的客户端会被阻塞)

2.未确定内容

  1. 对上文的部署方案是否有改进建议。
  2. 将Producers、Consumers直接集成到应用系统,还是再抽出一层?
  3. 对于一半以上的故障,如何预防?
    -- 如何获得宕机提醒?如何实现自动重启?
  4. 面向日志的采集,应该选择哪种消息传送模式(队列、发布/订阅)?
  5. 计划对上述的体系进行压力测试,以获取吞吐量的上限值;对测试的方案有何建议?

3.新问题

  1. Consumer异常阻塞是否会导致其他Consumer阻塞?

参考文章


  1. 基于zookeeper+leveldb搭建activemq集群
    主从部署的实施方案。
  2. 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
    简单了解ZooKeeper
  3. ActiveMQ实现负载均衡+高可用部署方案
    主从部署和集群部署的区别、实现
  4. Replicated LevelDB Store
    官网有对配置的参数进行详细的解说

AMQ学习笔记 - 14. 实践方案:基于ZooKeeper + ActiveMQ + replicatedLevelDB的主从部署的更多相关文章

  1. AMQ学习笔记 - 15&period; 实践方案:基于ActiveMQ的统一日志服务

    概述 以ActiveMQ + Log4j + Spring的技术组合,实现基于消息队列的统一日志服务. 参考:Spring+Log4j+ActiveMQ实现远程记录日志——实战+分析 与参考文章的比较 ...

  2. AMQ学习笔记 - 20&period; 使用Apache ActiveMQBrowser监控ActiveMQ

    概述 Apache ActiveMQBrowser可以用于查看AMQ中的消息.这里对其使用方法进行简单介绍. 使用介绍 1.下载并解压缩 下载地址:Apache ActiveMQBrowser,当前最 ...

  3. 并发编程学习笔记&lpar;14&rpar;----ThreadPoolExecutor(线程池)的使用及原理

    1. 概述 1.1 什么是线程池 与jdbc连接池类似,在创建线程池或销毁线程时,会消耗大量的系统资源,因此在java中提出了线程池的概念,预先创建好固定数量的线程,当有任务需要线程去执行时,不用再去 ...

  4. Ext&period;Net学习笔记14:Ext&period;Net GridPanel Grouping用法

    Ext.Net学习笔记14:Ext.Net GridPanel Grouping用法 Ext.Net GridPanel可以进行Group操作,例如: 如何启用Grouping功能呢?只需要在Grid ...

  5. java之jvm学习笔记五&lpar;实践写自己的类装载器&rpar;

    java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...

  6. VSTO学习笔记(七)基于WPF的Excel分析、转换小程序

    原文:VSTO学习笔记(七)基于WPF的Excel分析.转换小程序 近期因为工作的需要,要批量处理Excel文件,于是写了一个小程序,来提升工作效率. 小程序的功能是对Excel进行一些分析.验证,然 ...

  7. SQL反模式学习笔记14 关于Null值的使用

    目标:辨别并使用Null值 反模式:将Null值作为普通的值,反之亦然 1.在表达式中使用Null: Null值与空字符串是不一样的,Null值参与任何的加.减.乘.除等其他运算,结果都是Null: ...

  8. golang学习笔记14 golang substring 截取字符串

    golang学习笔记14 golang substring 截取字符串golang 没有java那样的substring函数,但支持直接根据 index 截取字符串mystr := "hel ...

  9. &period;NET MVC 学习笔记(四)— 基于Bootstarp自定义弹出框

    .NET MVC 学习笔记(四)—— 基于Bootstarp自定义弹出框 转载自:https://www.cnblogs.com/nele/p/5327380.html (function ($) { ...

随机推荐

  1. Offline&period;js - 自动判断网络连接状态并提醒用户

    http://www.cnblogs.com/lhb25/p/offline-js-alert-users-when-no-internet-connectivity.html 使用 jslint/j ...

  2. 多线程编程4 - NSOperationQueue

    一.简介 一个NSOperation对象可以通过调用start方法来执行任务,默认是同步执行的.也可以将NSOperation添加到一个NSOperationQueue(操作队列)中去执行,而且是异步 ...

  3. Android Preference

    http://blog.csdn.net/liuhe688/article/details/6448423 这个被google废弃了,替换方案是?

  4. &lbrack;ios&rsqb;&lbrack;swift&rsqb;swift混编

    http://blog.csdn.net/iflychenyang/article/details/8876542(如何在Objective-C的头文件引用C++的头文件) 1.将.m文件扩展名改为. ...

  5. PL&sol;SQL语句块提高1&plus;case语句

    set serveroutput on; declare --默认值的bianliang v_a ; -- v_b integer; --用stud.id 的类型 v_id stud.id%type; ...

  6. javascript函数作用域及this指向详解

    一.先说一个简单的概念--变量提升: 通过function+函数名的方式,声明的函数,可以在代码中的任何位置调用: 通过var定义变量的方式,声明的函数,则必须在声明之后进行调用,原因就是在变量定义之 ...

  7. CentOS7下使用yum安装MariaDB

    从CentOS 7开始,使用 MariaDB 替代默认的 MySQL.MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MyS ...

  8. SEO需要掌握的基础知识

    什么是SEO?  官方解释:  SEO是指通过对网站内部调整优化及站外优化,使网站满足搜索引擎收录排名需求,在搜索引擎中提高关键词排名, 从而把精准用户带到网站,获得免费流量,产生直接销售或品牌推广 ...

  9. 课程五&lpar;Sequence Models&rpar;,第二 周(Natural Language Processing &amp&semi; Word Embeddings) —— 0&period;Practice questions:Natural Language Processing &amp&semi; Word Embeddings

    [解释] The dimension of word vectors is usually smaller than the size of the vocabulary. Most common s ...

  10. day06 内存地址 小数据池缓存机制

    1. 内存相关 示例一 v1=[11,22,33] v2=[11,22,33] #值相等 内存地址不等 v1=11 v2=11 #按理说内存地址应该不等,但是python为了优化使其内存地址相等 v1 ...