Zookeeper-源码启动

源码启动zookeeper

zookeeper源码下载地址:

md-end-block 复制代码
//选择分支3.5.8
https://github.com/apache/zookeeper.git  

源码导入idea后,org.apache.zookeeper.Version类会报错,需要建一个辅助类

md-end-block 复制代码
//全局搜索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";
}

然后在根目录编译执行:

md-end-block 复制代码
mvn clean install -DskipTests

本地编译一直报org.apache.commons.collections.ExtendedProperties这个错误,不知道怎么解决。所以上传到云服务器后执行编译命令

后来发现修改插件版本可以解决上面的问题:

md-end-block 复制代码
<plugin>
    <artifactId>maven-remote-resources-plugin</artifactId>
    <version>1.6.0</version>
    <dependencies>
    	<dependency>
    		<groupId>commons-collections</groupId>
    		<artifactId>commons-collections</artifactId>
    		<version>3.2.1</version>
    	</dependency>
    	<!-- https://mvnrepository.com/artifact/commons-lang/commons-lang -->
		<dependency>
    		<groupId>commons-lang</groupId>
    		<artifactId>commons-lang</artifactId>
    		<version>2.6</version>
    	</dependency>
    </dependencies>
</plugin>

从bin目录下的zkServer.sh或zkServer.cmd里找到启动主类

md-end-block 复制代码
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 目录下,这样项目启动时才会打印日志

相关推荐
仟濹8 分钟前
【Java加强】1 异常 | 打卡day1
java·开发语言·python
AllData公司负责人19 分钟前
【亲测好用】实时开发平台能力演示
java·c语言·数据库
pcm12356720 分钟前
设计C/S架构的IM通信软件(3)
java·c语言·架构
走遍西兰花.jpg34 分钟前
spark配置
大数据·分布式·spark
咖啡啡不加糖34 分钟前
Grafana 监控服务指标使用指南:打造可视化监控体系
java·后端·grafana
€81137 分钟前
Java入门级教程26——序列化和反序列化,Redis存储Java对象、查询数据库与实现多消费者消息队列
java·拦截器·序列化和反序列化·数据库查询·redis存储java对象·多消费者消息队列
多多*1 小时前
Mysql数据库相关 事务 MVCC与锁的爱恨情仇 锁的层次架构 InnoDB锁分析
java·数据库·windows·sql·oracle·面试·哈希算法
hellojackjiang20111 小时前
如何保障分布式IM聊天系统的消息可靠性(即消息不丢)
分布式·网络安全·架构·信息与通信
cyforkk1 小时前
15、Java 基础硬核复习:File类与IO流的核心逻辑与面试考点
java·开发语言·面试
李少兄1 小时前
解决 org.springframework.context.annotation.ConflictingBeanDefinitionException 报错
java·spring boot·mybatis