简介
Zookeeper 是 apache 基金组织下的项目,项目用于简单的监控和管理一组服务,通过简单的接口就可以集中协调一组服务,如配置管理,信息同步,命名,分布式协调。
Zookeeper 是使用Java 语言编写的,我们需要提前安装Java. 通过一下命令检查Java 是否安装
java --version
假如这一步能够正确显示Java的版本, 你可以直接到下一步。 如果显示的信息是 no such file or directory。 那么你就需要安装 Java.
Java 现在已经有不同的版本了,按照你的需求安装合适的版本
sudo useradd zookeeper -m
-m 参数是用于在创建用户的同时创建 Home 目录。 上面的脚本会创建目录 /home/zookeeper. 如想使用不同的名称,只要替换 zookeeper 就可以。
sudo usermod --shell /bin/bash zookeeper
sudo passwd zookeeper
sudo usermod -aG sudo zookeeper
sudo getent group sudo
在真正安装 zookeeper 之前我们需要创建一个可以用于存储 zookeeper 数据和配置的文件夹。 执行下列脚本创建zookeeper 的数据目录
sudo mkdir -p /data/zookeeper
设置zookeeper 用户为此目录的所有者
sudo chown -R zookeeper:zookeeper /data/zookeeper
cd /opt
sudo wget https://dlcdn.apache.org/zookeeper/zookeeper-3.9.1/apache-zookeeper-3.9.1-bin.tar.gz
sudo tar -xvf apache-zookeeper-3.9.1-bin.tar.gz
需要注意的是,以上两个步骤的链接地址还有文件名称,只是一个例子,具体还是需要根据你下载的文件做调整
sudo mv apache-zookeeper-3.9.1-bin zookeeper
sudo chown -R zookeeper:zookeeper /opt/zookeeper
为 zookeeper 创建一个配置文件, 这个配置仅仅用于单机模式(测试环境或者开发环境)。 如果是生产环境,看第六步.
- cd /opt/zookeeper/conf/
-
- sudo cp zoo_sample.cfg zoo.cfg
-
- sudo nano zoo.cfg
修改数据目录地址配置项为: /data/zookeeper. 其他项目保持不变,保存并退出。
首先切换当前的用户到 zookeeper 用户
su zookeeper
启动服务
/opt/zookeeper/bin/zkServer.sh start
如果如下显示出 “STARTED",那么说明服务启动成功了。
第七步: 链接 zookeeper 服务
使用脚本链接本地的zookeeper 服务
/opt/zookeeper/bin/zkCli.sh -server 127.0.0.1:2181
如果显示 “CONNECTED” 则说明链接成功
执行 help 查询命令说明
输入命令:
quit
停止zookeeper 服务
/opt/zookeeper/bin/zkServer.sh stop
sudo nano /etc/systemd/system/zookeeper.service
- [Unit]
- Description=Zookeeper Daemon
- Documentation=http://zookeeper.apache.org
- Requires=network.target
- After=network.target
-
- [Service]
- Type=forking
- WorkingDirectory=/opt/zookeeper
- User=zookeeper
- Group=zookeeper
- ExecStart=/opt/zookeeper/bin/zkServer.sh start /opt/zookeeper/conf/zoo.cfg
- ExecStop=/opt/zookeeper/bin/zkServer.sh stop /opt/zookeeper/conf/zoo.cfg
- ExecReload=/opt/zookeeper/bin/zkServer.sh restart /opt/zookeeper/conf/zoo.cfg
- TimeoutSec=30
- Restart=on-failure
-
- [Install]
- WantedBy=default.target
sudo systemctl daemon-reload
- systemctl start zookeeper
- systemctl enable zookeeper
systemctl status zookeeper
如果你看到高亮的 active (running) 则说明服务成功启动
集群模式下,首先你需要准备多个 Ubuntu 机器实例。并且按照第二章节的逐个安装配置。
nano /data/zookeeper myid
文件内容就是此服务的id
1
循环上一个步骤,以此给每个服务器创建一个唯一的id.
nano /opt/zookeeper/conf/zoo.cfg
内容如下:
- # 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=/data/zookeeper
- # 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
-
- ## Metrics Providers
- #
- # https://prometheus.io Metrics Exporter
- #metricsProvider.className=org.apache.zookeeper.metrics.prometheus.PrometheusMetricsProvider
- #metricsProvider.httpPort=7000
- #metricsProvider.exportJvmInfo=true
-
- server.1=[server_ip]:2888:3888
- server.2=[server_ip]:2888:3888
- server.3=[server_ip]:2888:3888
systemctl restart zookeeper.service