zookeeper服务器端运行于两种模式下:独立模式(standalone)和仲裁模式(quorum)。独立模式:有一个单独的服务器,zookeeper状态没法复制。仲裁模式:具备一组zookeeper服务器,咱们称为zookeeper集群(zookeeper ensemble),它们以前能够进行状态的复制,并同时服务于客户端的请求。node
下载地址:https://archive.apache.org/dist/zookeeper/zookeeper-3.5.5/apache-zookeeper-3.5.5-bin.tar.gz
zookeeper是用Java语言编写的,系统中必定要安装jdk才能启动zookeeper。
首先咱们以独立模式运行zookeeper并建立一个会话。
上传至Linux服务器,解压:apache
[root@localhost opt]# tar xvf apache-zookeeper-3.5.5-bin.tar.gz -C /opt/
若是使用的是Windows系统,可使用winzip的解压缩工具进行解压发行包。vim
在发行包(distribution)的目录中,你会发如今bin目录中有启动zookeeper的脚本。以.sh结尾的脚步运行在Unix平台,以.cmd结尾的脚本则用于Windows。在conf目录中保存配置文件 。lib目录包括Java的jar文件,它们是运行zookeeper所须要的第三方支持。
修改配置文件:服务器
[root@localhost zookeeper]# cd conf/ [root@localhost conf]# mv zoo_sample.cfg zoo.cfg [root@localhost conf]# vim zoo.cfg dataDir=/opt/zookeeper/dataDir
官方不推荐使用默认的dataDir,修改dataDir保存退出。
zookeeper的配置项:
zookeeper的配置项在zoo.cfg配置文件中配置,另外有些配置能够经过Java系统属性来进行配置。下面列出了3个重要的配置项:session
启动服务器,执行以下命令:架构
[root@localhost conf]# cd .. [root@localhost zookeeper]# bin/zkServer.sh start ZooKeeper JMX enabled by default Using config: /opt/zookeeper/bin/../conf/zoo.cfg Starting zookeeper ... STARTED
这个服务器端命令使得zookeeper服务器在后台中运行。若是在前台运行以便查看服务器输出,可使用如下命令运行:dom
[root@localhost zookeeper]# bin/zkServer.sh start-foreground
这个选项提供了大量详细信息的输出,以便容许查看服务器发生了什么。
启动后,查看日志文件是否有报错信息:ide
[root@localhost zookeeper]# cd logs/ [root@localhost logs]# ll total 8 -rw-r--r-- 1 root root 7516 Oct 21 18:28 zookeeper-root-server-localhost.localdomain.out [root@localhost logs]# grep -E -i "((exception)|(error))" *
查询结果为空,则没有报错信息。
如今使用zookeeper客户端链接zookeeper服务器,运行以下命令:工具
[root@localhost zookeeper]# bin/zkCli.sh ......... 2019-10-21 18:37:35,242 [myid:localhost:2181] - INFO [main-SendThread(localhost:2181):ClientCnxn$SendThread@959] - Socket connection established, initiating session, client: /0:0:0:0:0:0:0:1:39276, server: localhost/0:0:0:0:0:0:0:1:2181 2019-10-21 18:37:35,308 [myid:localhost:2181] - INFO [main-SendThread(localhost:2181):ClientCnxn$SendThread@1394] - Session establishment complete on server localhost/0:0:0:0:0:0:0:1:2181, sessionid = 0x1000132e0500000, negotiated timeout = 30000 WATCHER:: WatchedEvent state:SyncConnected type:None path:null [zk: localhost:2181(CONNECTED) 0]
经过上面信息,得知zookeeper客户端与服务器端创建的链接。ui
查看根(root)下的全部znode:
[zk: localhost:2181(CONNECTED) 3] ls -R / / /zookeeper /zookeeper/config /zookeeper/quota
建立一个名为workers的znode:
[zk: localhost:2181(CONNECTED) 4] create /workers Created /workers [zk: localhost:2181(CONNECTED) 7] ls -R / / /workers /zookeeper /zookeeper/config /zookeeper/quota
删除建立的workers节点,并退出zkCli:
[zk: localhost:2181(CONNECTED) 8] delete /workers [zk: localhost:2181(CONNECTED) 9] ls -R / / /zookeeper /zookeeper/config /zookeeper/quota [zk: localhost:2181(CONNECTED) 10] quit WATCHER:: WatchedEvent state:Closed type:None path:null 2019-10-21 19:35:46,321 [myid:] - INFO [main:ZooKeeper@1422] - Session: 0x1000132e0500000 closed 2019-10-21 19:35:46,322 [myid:] - INFO [main-EventThread:ClientCnxn$EventThread@524] - EventThread shut down for session: 0x1000132e0500000
关闭zookeeper服务器:
[root@localhost zookeeper]# bin/zkServer.sh stop ZooKeeper JMX enabled by default Using config: /opt/zookeeper/bin/../conf/zoo.cfg Stopping zookeeper ... STOPPED
经过查看zkServer.sh脚本得知可接受6个参数,以下:start:启动服务start-foreground:前台启动服务print-cmd:打印命令行信息stop:中止服务restart:重启服务(先中止,后启动)status:服务状态