一、问题背景

生产环境Windows机器上用的Zookeeper 3.4.6,最近经常报如下异常:

经过搜索,看到一篇帖子可以解决:https://www.jianshu.com/p/73eec030db86

但需要通过编译Zookeeper源代码的方式进行解决,于是有了本文的一番操作

二、编译过程

1.从Github上下载ZooKeeper源代码

https://github.com/apache/zookeeper

2.下载并安装Ant:http://ant.apache.org/

ZooKeeper 3.4.6是基于Ant进行构建的,不是基于Maven

下载时需要根据JDK版本,下载不同的Ant版本

我安装的是JDK1.8,所以下载了Ant 1.10版本

The Apache Ant team currently maintains two lines of development. 
The 1.9.x releases require Java5 at runtime and 1.10.x requires Java8 at runtime.

 解压后,在Windows环境变量中设置一下ANT_HOME

并在PATH环境变量中添加ANT的bin目录

3.修改http为https

这是ZooKeeper编译过程中最坑的一个地方!

访问http://repo1.maven.org时始终有问题,用了梯子也不好使,搜了一下,原来对Maven中央仓库的访问,从2020年1月15日起,不再支持http了:

https://central.sonatype.org/articles/2019/Apr/30/http-access-to-repo1mavenorg-and-repomavenapacheorg-is-being-deprecated/

https://blog.sonatype.com/central-repository-moving-to-https

https://twitter.com/sonatype_ops

修改下载的Zookeeper源代码根目录底下的ivysettings.xml,将里面的http改为https:

修改下载的Zookeeper源代码根目录底下的build.xml,将里面的http改为https:

4.打开CMD命令窗口,切换到下载的Zookeeper源代码根目录,执行ant eclipse命令,如果看到下面的画面,恭喜编译成功了:

5.导入到Intellij IEDA

前几个步骤执行完,构建的是一个Eclipse工程,所以导入到Intellij IDEA时,要选择Eclipse

选择jdk 1.8

看build.xml中,java编译的版本是1.5

    <property name="javac.target" value="1.5" />
<property name="javac.source" value="1.5" />所以  

所以需要在Settings中设置编译的目标字节码输出为jdk 5:

在Project Structure中设置语言级别为jdk 5:

三、运行编译后的ZooKeeper

1.将conf目录下的zoo_sample.cfg复制为zoo.cfg,并设置dataDir以及dataLogDir:

2.找到运行主类:org.apache.zookeeper.server.ZooKeeperServerMain,并设置启动配置

3.启动ZooKeeper

四、解决生产环境异常:java.nio.channels.CancelledKeyException

1.根据补丁文件,修改源代码:

第一处修改:

第二处修改:

第三处修改:

2.生成新的jar

在Intellij IDEA中设置Ant编译,点击jar阶段,会在build目录生成最终的ZooKeeper-3.4.6.jar

五、解决编译时下载不了jar包

1.准备一个梯子,设置代理

下载过程中,需要从墙外下载大量的 jar包,有了梯子,会省很多事

打开Zookeeper源代码根目录底下的build.xml,增加针对梯子的代理

2.在编译的过程中,如果没有梯子或者有梯子也不管用,可以看看报错的行数,比如:

如果这些编译时下载不下来,可以看看它的条件,就是“除非相应的jar已经存在”,否则就去下载

改的时候,要注意那个“usetimestamp”,如果是true,改为false,否则编译时可能不认我们手动下载的那个jar,因为时间戳可能对不上

将相关的jar下载下来,解压后,放到它需要的目录底下:

编译Zookeeper3.4.6源代码并通过Intellij IDEA运行(2020年)的更多相关文章

  1. 在Linux上编译dotnet cli的源代码生成.NET Core SDK的安装包

    .NET 的开源,有了更多的DIY乐趣.这篇博文记录一下在新安装的 Linux Ubuntu 14.04 上通过自己动手编译 dotnet cli 的源代码生成 .net core sdk 的 deb ...

  2. 编译Android4.3内核源代码

     --------------------------------------------------------------------------------------------------- ...

  3. 【转】基于Ubuntu 14.04 LTS编译Android4.4.2源代码

    原文网址:http://blog.csdn.net/gobitan/article/details/24367439 基于Ubuntu 14.04 LTS编译Android4.4.2源代码       ...

  4. 编译android-4.3.1_r源代码并刷到自己的Galaxy Nexus I9250真机上

    编译android-4.3.1_r源代码并刷到自己的Galaxy Nexus I9250真机上 作者:雨水  日期:2014-04-30 编译源码的目的还是为了自己改动源码,然后还可以执行在相应的手机 ...

  5. 反编译Apk得到Java源代码

    原文章转载自:http://hi.baidu.com/%CB%BF%D4%B5%CC%EC%CF%C2/blog/item/2284e2debafc541e495403ec.html 本人转载自:ht ...

  6. 基于Ubuntu 14.04 LTS编译Android4.4.2源代码

    转载自:雨水:http://blog.csdn.net/gobitan/article/details/24367439 基于Ubuntu 14.04 LTS编译Android4.4.2源代码     ...

  7. Linux下编译VLC for Android源代码总结

    转:http://blog.chinaunix.net/uid-26611383-id-3678766.html 由于项目需要,需要一个在android平台能够支持RTSP协议的播放器,由于之前没有a ...

  8. 编译Android 4.4源代码并烧录到Nexus4

    环境准备: 基本环境:ubuntu-12.04-desktop-64bit(裸机或者Windows下虚拟机安装均可,14.04也可以) 其他要求:空闲磁盘空间100G以上,代码部分接近10G,内存越大 ...

  9. IntelliJ IDEA 运行你的第一个Java应用程序

    IntelliJ IDEA 运行你的第一个Java应用程序创建项目让我们创建一个简单的Java Hello World项目. 单击创建新的项目. 打开新建项目向导.你应该注意的主要是项目的SDK.SD ...

随机推荐

  1. virtualenv 个人指南

    virtualenv是解决一个机器上多个应用需要的Python版本不一致的问题,virtualenv就是用来为一个应用创建一套"隔离"的Python运行环境,解决了解决了不同应用间 ...

  2. 【U创营学员招募】8节免费云计算课程,让你轻松掌握生产技能

    课程不错,免费听课.免费听课.免费听课,强烈推荐-! 公众号对话框回复"课程助手" 即可报名! ---END---

  3. Welcome to Giyber Blog - LC的博客

    "You can be the best! " 一切才刚开始 "不知道行不行,试试吧."抱着这样的理由,一个小白的成长记录,由此开始. 在 Mr.锤 的&quo ...

  4. jquery和zepto的异同

    相同点 相同点: zepto: 是jquery 的 阉割版 是为移动端开发的库 jQuery的轻量级替代品.文件大小比较小 只有8k左右 ,是目前功能库中最小的一个,尽管不大,zepto 所提供的工具 ...

  5. 在Docker中运行gocd

    gocd是一个持续集成的工具,可视化效果非常好 运行gocd-server 12345 docker run -d --name server -p8153:8153 -p8154:8154 -v / ...

  6. yum配置与使用

    yum的配置一般有两种方式,一种是直接配置/etc目录下的yum.conf文件,另外一种是在/etc/yum.repos.d目录下增加.repo文件. 一.yum的配置文件 [main] cached ...

  7. JAVA中对list map根据map某个key值进行排序

    package test; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; ...

  8. 【h5ai】搭建服务器目录

    在前几天,我帮人安装h5ai这个东西,结果直接踩坑,装了一个下午,打算自己也装一个,顺便写一下教程 最终效果演示: https://larsjung.de/h5ai/demo/ 服务器 服务器这里推荐 ...

  9. 学了C++不知道怎么搞后台开发?先看看这份学习路线吧!

    作者:AJ 在去年结束的秋季招聘中,后台开发或服务器开发的岗位需求一度火热,甚至超过了算法岗.不少同学从诸神黄昏的算法岗战场上退下,转向更偏向工程能力的后台开发岗,从而造成后台开发岗位竞争的大爆发. ...

  10. AF(操作者框架)系列(3)-创建第一个Actor的程序

    这节课的内容,语言描述基本是无趣的,就是一个纯程序编写,直接上图了. 如果想做其他练习,可参考前面的文章: https://zhuanlan.zhihu.com/p/105133597 1. 新建一个 ...