设为首页 收藏本站
查看: 1039|回复: 0

[经验分享] 使用javac编译zookeeper项目

[复制链接]

尚未签到

发表于 2017-3-2 10:43:03 | 显示全部楼层 |阅读模式
这里记录zookeeper编译源代码上的一些细节的问题.
    网上不少关于如何使用ant eclipse来构建zookeeper对应的eclipse工程的记录.这里就不再过多赘述.只做简单阐述.
    这里主要阐述一下如何不使用任何工具直接使用javac的方式来编译zookeeper项目,并且直接使用java来运行.
  一.使用ant构建eclispe工程编译法非常简单.就是在github将zookeeper项目代码下载下来.里面已经有写好的build.xml和ivy.xml及设置文档.会将所有相关依赖下载下来.并且进行构建编译.编译完成之后直接在eclispe里导入即可.非常简单.
  二.如果在linux上没有任何ant,maven等环境的话.想编译zookeeper等大型项目的时候只能通过javac的方式了.
    使用javac的方式来编译zookeeper的话会发现zookeeper的java源代码目录包里少了org.apache.zookeeper.data和org.apache.zookeeper.proto.这两个包里一个实现的是zookeeper ACL的相关一个实现的是通信协议相关的各种命令.
    并且不仅仅是这两个包没有.而且相关的很多依赖也没有.zookeeper依赖的jar列表如下:



commons-cli-1.2.jar
jackson-core-asl-1.9.11.jar
jackson-mapper-asl-1.9.11.jar
javacc.jar
jetty-6.1.26.jar
jetty-util-6.1.26.jar
jline-2.11.jar
log4j-1.2.17.jar
netty-3.10.5.Final.jar
servlet-api-2.5-20081211.jar
slf4j-api-1.7.5.jar
slf4j-log4j12-1.7.5.jar
  下载这些依赖jar包之后,设置到classpath变量中去.具体如何便捷设置.最后会有介绍.
    有了依赖的包.但是zookeeper本身的两个源代码包却不在源代码目录里.这里很多人会迷糊.为何会缺少源代码包.ant编译的时候如何去找对应的源代码包呢.
    实际上zookeeper项目将所有的源代码打包成jar包上传到repo1.maven.org/maven2/org/apache/zookeeper/zookeeper下.使用ivy解决依赖问题的时候会自动去搜索是否有对应的jar文件,并下载下来.使用ant构建完之后会发现在源代码目录里多了个generated的目录.在这个目录里缺少的源代码项目包就在这里.
    所以当自己手动构建的时候需要自己去maven上将这个zookeeper-<version>-source.jar文件下载下来解压到对应的目录里.
    所有东西都齐全之后就可以使用javac进行编译了.将所有文件带着包路径放到一个文件里.然后通过javac 编译这个包文件即可.



#find ./ -name '*.java' >source_list  所有源代码文件的集合.
#javac -d ./build @source_list       这样编译完之后会按包路径生成在当前目录的build目录下
  编译成功之后可以直接通过java来运行.java org.apache.zookeeper.server.quorum.QuorumPeerMain config.cfg 就可以运行.
  三.在使用javac编译的时候比较费事的就是超长的classpath设置问题.
    快速设置classpath的方法就是写一个简单的bash函数放到/etc/profile里.通过这个函数来设置classpath.



function classpath(){
local path=$1
find $path -name \*.jar | awk '{if(NR==1){jarp=$0}else{jarp=jarp":"$0}}END{print jarp}'
}  #函数的作用就是找出给出的目录下所有的jar文件,然后生成符合PATH格式的xxx:xxx:xxx的形式.

export JAVA_HOME=/home/cloud/install/jdk1.7.0_75
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH:.
export CLASSPATH=.:..:$(classpath $JAVA_HOME)
export CLASSPATH=$CLASSPATH:$(classpath '/home/user/install/jar') #像这样直接把依赖的jar包放到这个目录里然后这样设置classpath就可以轻松使用javac编译大型项目了.就算是hadoop这样的项目只要classpath设置全面有依然能正常编译.
#在编译完之后需要将存放class文件的目录也添加到classpath中.这样使用java运行时才不会有问题.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-349202-1-1.html 上篇帖子: spark 都用了哪些开源东东 下篇帖子: Spring Boot的启动器Starter详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表