使用javac编译zookeeper项目
这里记录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运行时才不会有问题.
使用javac编译zookeeper项目的更多相关文章
- 用javac编译整个j2ee项目
转自:http://www.blogjava.net/zhyiwww/archive/2011/10/13/361145.html 我们做项目,可能会使用ant做系统集成和部署.其实ant在编译项目时 ...
- Ant 命令行编译Android项目
首先把android sdk下的tools目录加到系统path环境变量里, 要么就得直接指定android.bat的绝对路径 对于一个新项目, 可以用这个命令创建需要的ant编译环境(可以看到andr ...
- Java_java动态编译整个项目,解决jar包找不到问题
java动态编译整个项目,解决jar包找不到问题原文:http://itzyx.com/index.php/javac/ 动态将java文件编译为class文件解决方案:将temp\sdl\src目录 ...
- ANT入门&用ANT编译java项目
第一次接触ant是15年在无锡某软件公司实习时,当时的项目是由多个模块组成,开发分成模块开发的几个小组.为了提高开发效率,采用这种编译项目的方法. 最近接触到flex项目,采用eclipse自动编译的 ...
- 命令行编译java项目
命令行编译java项目 项目名: testproj 目录 src -> cn -> busix -> test bin lib 编译项目 cd testproj javac -d . ...
- 一个使用命令行编译Android项目的工具类
一个使用命令行编译Android项目的工具类 简单介绍 编译apk项目须要使用的几个工具,基本都在sdk中,它们各自是(Windows系统): 1.aapt.exe 资源打包工具 2.android. ...
- javac编译不同目录的源码提示找不到符号
对于单个文件的且不引用其他类文件的java源码用javac编译大家都很熟悉即 javac mycode.java 但是如果这个文件引用到了其他的类文件,在进行编译的时候就会提示找不到符号,这时我们需要 ...
- win7(x64)下安装cocos2d并编译安卓项目
好吧,不为啥,就是如题. win7 x64 脑袋内存比较小,说不定明儿就忘了,今天记录一下. 没有什么经验,所有步骤基本都是百度出来的,这里边操作边记录,为了保护原创作者,这里我都附上我查找的链接. ...
- VS低版本打开高版本解决方案(如08打开10、12、13版本vs编译的项目)
一.vs2005打开vs2008编译的项目:1.用记事本打开sln文件,将: Microsoft Visual Studio Solution File, Format Version 10.00 # ...
随机推荐
- Python 基础之基本数据类型
首先,Python中的变量不需要声明.每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建.在Python中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象 ...
- o(n)线性排序算法
O(n) 排序算法 前言 前面有总结过各类常用的排序算法,但是那些排序算法最优的时间复杂度是O(nlogn),所以我要介绍三种时间复杂度为O(n)的线性时间复杂度的排序算法. 计数排序 计数排序利用了 ...
- Openstack & Ansible
Opennstack Open source software for creating private and public clouds Manages the servers at these ...
- chroot jail
注意,原标题是:Linux Virtualization using Chroot Jail,我实在不知道怎么翻译,所以,自作主张,选了chroot jail作为标题.原文地址 chroot jail ...
- python爬虫从入门到放弃(三)之 Urllib库的基本使用
官方文档地址:https://docs.python.org/3/library/urllib.html 什么是Urllib Urllib是python内置的HTTP请求库包括以下模块urllib.r ...
- R与并行计算(转)
文章摘要 本文首先介绍了并行计算的基本概念,然后简要阐述了R和并行计算的关系.之后作者从R用户的使用角度讨论了隐式和显示两种并行计算模式,并给出了相应的案例.隐式并行计算模式不仅提供了简单清晰的使用方 ...
- Nagios配置安装详解
nagios.html :first-child{margin-top:0!important}img.plugin{box-shadow:0 1px 3px rgba(0,0,0,.1);borde ...
- (原创)Maven+Spring+CXF+Tomcat7 简单例子实现webservice
这个例子需要建三个Maven项目,其中一个为父项目,另外两个为子项目 首先,建立父项目testParent,选择quickstart: 输入项目名称和模块名称,然后创建: 然后建立子项目testInt ...
- Java之线程同步练习
1.有一张银行卡:*属性:name,money(账户余额)* 多线程操作同一张银行卡: 金额:x(每次存钱取钱的数额,取钱时x为负数,存钱时x为整数) 定义一个add方法:用于存取钱,参数为x,即每次 ...
- Java IO流之转换流
一.转换流 1.在IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换流 2.转换流用于在字节流和字符流之间转换 3.转换流本身是字符流 二.两种转换流 Ou ...