欢迎来到天天文库
浏览记录
ID:5318070
大小:466.14 KB
页数:14页
时间:2017-12-08
《zookeeper管理员指南》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、1.部署本章节主要讲述如何部署ZooKeeper,包括以下三部分的内容:1.系统环境2.集群模式的配置3.单机模式的配置系统环境和集群模式配置这两节内容大体讲述了如何部署一个能够用于生产环境的ZK集群。如果仅仅是想在单机上将ZK运行起来,进行一些开发与测试,那么第三部分或许是你的菜。1.1系统环境1.1.1平台支持平台运行client运行server开发环境生产环境GNU/Linux√√√√SunSolaris√√√√FreeBSD√ⅹ,对nio的支持不好√√Win32√√√ⅹMacOSX√√√ⅹ注:运行client是指作为客户端,与server进行数据通
2、信,而运行server是指将ZK作为服务器部署运行。1.1.2软件环境ZooKeeperServer是一个Java语言实现的分布式协调服务框架,因此需要6或更高版本的JDK支持。集群的机器数量方面,宽泛的讲,其实是任意台机器都可以部署运行的,注意,这里并没有说一定要奇数台机器哦!通常情况下,建议使用3台独立的Linux服务器构成的一个ZK集群。1.2集群模式的配置为了确保ZooKeeper服务的稳定与可靠性,通常是搭建成一个ZK集群来对外提供服务。关于ZooKeeper,需要明确一个很重要的特性:集群中只要有过半的机器是正常工作的,那么整个集群对外就是可用
3、的(本文下面就用―过半存活即可用‖来代替这个特性吧^-^)。正是基于这个特性,建议是将ZK集群的机器数量控制为奇数较为合适。为什么选择奇数台机器,我们可以来看一下,假如是4台机器构成的ZK集群,那么只能够允许集群中有一个机器down掉,因为如果down掉2台,那么只剩下2台机器,显然没有过半。而如果是5台机器的集群,那么就能够对2台机器down掉的情况进行容灾了。你可以按照以下步骤来配置一个ZK机器,更多详细步骤请查看《ZooKeeper快速搭建》:1.安装JDK。相关链接:http://java.sun.com/javase/downloads/inde
4、x.jsp2.设置Javaheap大小。避免内存与磁盘空间的交换,能够大大提升ZK的性能,设置合理的heap大小则能有效避免此类空间交换的触发。在正式发布上线之前,建议是针对使用场景进行一些压力测试,确保正常运行后内存的使用不会触发此类交换。通常在一个物理内存为4G的机器上,最多设置-Xmx为3G。3.下载安装ZooKeeper,相关链接:http://zookeeper.apache.org/releases.html4.配置文件zoo.cfg。初次使用zookeeper,按照如下这个简单配置即可:1.tickTime=20002.dataDir=/va
5、r/lib/zookeeper/3.clientPort=21814.initLimit=55.syncLimit=2server.1=zoo1:2888:38886.server.2=zoo2:2888:38887.server.3=zoo3:2888:3888本文后续章节会对这些参数进行详细的介绍,这里只是简单说几点:A.集群中的每台机器都需要感知整个集群是由哪几台机器组成的,在配置文件中,可以按照这样的格式,每行写一个机器配置:server.id=host:port:port.关于这个id,我们称之为ServerID,标识host机器在集群中的机器序
6、号,在每个ZK机器上,我们需要在数据目录(数据目录就是dataDir参数指定的那个目录)下创建一个myid文件,myid中就是这个ServerID数字。B.在ZooKeeper的设计中,集群中任意一台机器上的zoo.cfg文件的内容都是一致的。因此最好是用SVN把这个文件管理起来,保证每个机器都能共享到一份相同的配置。5.关于myid文件。myid文件中只有一个数字,即一个ServerID。例如,server.1的myid文件内容就是―1‖。注意,请确保每个server的myid文件中id数字不同,并且和server.id=host:port:port中的
7、id一致。另外,id的范围是1~255。6.至此,配置文件基本ok,可以尝试使用如下命令来启动zookeeper了:1.$java-cpzookeeper.jar:lib/slf4j-api-1.6.1.jar:lib/slf4j-log4j12-1.6.1.jar:lib/log4j-1.2.15.jar:conforg.apache.zookeeper.server.quorum.QuorumPeerMainzoo.cfg注意,不同的ZK版本,依赖的log4j和slf4j版本也是不一样的,请看清楚自己的版本后,再执行上面这个命令。QuorumPeer
8、Main类会启动ZooKeeperServer,同时,JMXMB也
此文档下载收益归作者所有