- //选择分支3.5.8
- https://github.com/apache/zookeeper.git
源码导入idea后,org.apache.zookeeper.Version类会报错,需要建一个辅助类
- package org.apache.zookeeper.version;
-
- public interface Info {
- int MAJOR = 1;
- int MINOR = 0;
- int MICRO = 0;
- String QUALIFIER = null;
- int REVISION = -1;
- String REVISION_HASH = "1";
- String BUILD_DATE = "2020-10-15";
- }
然后在根目录编译执行:
mvn clean install -DskipTests
开源项目找入口类一般都是从启动脚本去找,可以从bin目录下的zkServer.sh或zkServer.cmd里找到启动主类运行即可
org.apache.zookeeper.server.quorum.QuorumPeerMain
注意:
1、将conf文件夹里的zoo_sample.cfg文件复制一份改名为zoo.cfg,将zoo.cfg文件位置配置到启动参数里
2、启动之前需要先将zookeeper-server项目里pom.xml文件里依赖的包(除了jline)的scope为provided这一行全部注释掉
3、将conf文件夹里的log4j.properties文件复制一份到zookeeper-server项目的 \target\classes 目录下,这样项目启动时才会打印日志
用客户端命令连接源码启动的server:
bin/zkCli.sh -server 192.168.1.62:2181
从源码里运行客户端(org.apache.zookeeper.ZooKeeperMain),注意需要加入启动参数,见下图:
如果要配置集群启动,需要复制3个zoo.cfg文件,并在dataDir目录下建对应的myid文件,启动的参数也要做对应的修改