1) Zookeeper集群几个配置项
2) 如何启动Zookeeper各个节点和查看节点状态
3) Zookeeper 客户端命令行连接及基本命令使用(create、ls、get、rmr等命令)
Zookeeper从设计模式角度来看,是一个基于观察着模式设计的分布式服务管理框架,他负责存储和管理大家所关心的数据,然后接受观察者的注册,一旦这些数据的状态发生变化,zookeeper就将负责通知已经在zookeeper上注册的那些观察者做出相应的反应,从而实现集群中类似Master/Slave管理模式。
统一命名服务(Name Service).
配置管理(Configuration Management)
集群管理(Group Membership)
共享(Locks)/同步锁
(1).下载地址:
zookeeper-3.4.5下载
(2).赋执行权限:
chmod u+x zookeeper-3.4.5.tar.gz
(3).解压:
tar -zxvf zookeeper-3.4.5.tar.gz -C /opt/modules/
cp conf/zoo_sample.cfg conf/zoo.cfg
配置数据存储目录:
dataDir=/opt/modules/zookeeper-3.4.5/data
创建数据存储目录:
mkdir /opt/modules/zookpeer-3.4.5/data
bin/zkServer.sh start
查看状态:bin/zkServer.sh status
Client Shell:bin/zkCli.sh
这个时间是作为Zookeeper服务器之间或者客户端与服务器之间维持心跳的时间间隔,也就是每个tickTime时间就会发送一下心跳。
Zookeeper保存数据的目录,默认情况下,Zookeeper将数据的日志文件也保存在这里。
这个端口就是客户端连接Zookeeper服务器的端口。Zookeeper会监听这个端口,接受客户端的访问请求。
这个配置项是用来配置zookeeper接受客户端的(这里所说的客户端不是用户连接Zookeeper服务器的客户端而是Zookeeper服务器集群中连接到Leader的Follower服务器)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过10个心跳的时间(也就是tickTime)长度后Zookeeper服务器还没有接到客户端的返回信息,那么表明这个客户端连接失败。总时间长度就是5*2000=10秒。
这个配置项标示Leader与Follower之间发送消息、请求和应答时间长度,最长不能超过多少个tickTime的时间长度,总的时间长度就是2*2000=4秒。
其中A是一个数字,标示这是第几号服务器;B是这个服务器的ip地址;C标示的是这个服务器与集群中的Leader服务器交换信息的端口;D标示的是万一集群中Leader服务器挂了,需要一个端口来进行选举,选出一个新的Leader,而这个端口就是用来执行选举时服务器相互通信的端口。如果是伪集群的配置方式,由于B都是一样,所以不同的Zookeeper实例通信端口号不能一样,所以要给他们分配不同的端口号。
集群模式下配置一个文件myid,这个文件在daraDir目录下,这个文件里面就有一个数据就是A的值,Zookeeper启动时读取此文件,拿到里面的数据与zoo.cfg里面的配置信息比较从而判断到底是哪个server。
命令:bin/zkCli.sh -server localhost:2181
ls ,get ,create,delete ,set .
查看时间服务器
sudo rpm -qa|grep ntpd
sudo service ntpd status
启动时间服务器
sudo service ntpd start
执行指令:
sudo vi /etc/ntp.conf
打开配置文件配置如下内容:
(1). 修改网段为我们主机所在网段
restrict 192.168.154.0 mask 255.255.255.0 nomodify notrap
(2). 增加下面注释内容
#server 0.centos.pool.ntp.org
#server 1.centos.pool.ntp.org
#server 2.centos.pool.ntp.org
(3). 去掉以下注释
server 127.127.1.0 # local clock
fudge 127.127.1.0 stratum 10
sudo vi /etc/sysconfig/ntpd
首行增加内容如下:
SYNC_HWCLOCK=yes
crontab -e
在编辑框内输入以下内容:
0-9/10 * * * * /usr/sbin/ntpdate miaodonghua.host
也可以直接使用命令手动同步时间:
/usr/sbin/ntpdate miaodonghua.host
sudo chkconfig --level 35 crond on
sudo service crond start
执行后就与主机miaodonghua.host时间保持一致了。
$tar -zxvf zookeeper-3.4.5.tar.gz /opt/app/
$mv conf/zoo_sample.cfg conf/zoo.cfg
1,创建数据存储目录。
mkdir -p /opt/app/zookeeper-3.4.5/data/zkData/
2,配置数据存储目录。(vi zoo.cfg)
dataDir=/opt/app/zookeeper-3.4.5/data/zkData
3,添加配置Zookeeper服务器的地址及编号
server.1=miaodonghua.host:2888:3888
server.2=miaodonghua.host1:2888:3888
server.3=miaodonghua.host2:2888:3888
4,在虚拟机中创建对应的编号。
在命令行里输入:
vi data/zkData/myid
添加数字内容:1(根据第三步的配置填写这个数字)。
5,分发到另外两台机器。
$scp -r zookeeper-3.4.5/ hadoop@miaodonghua1.host:/opt/app/
$scp -r zookeeper-3.4.5/ hadoop@miaodonghua2.host:/opt/app/
$bin/zkServer.sh start
$bin/zkServer.sh status
$bin/zkCli.sh -server miaodonghua.host