Ambari 2.5.2源码编译打包

本文分享了Ambari2.5.2版本编译打包的成功经验,包括设置五位版本号、使用阿里云Maven源、解决依赖下载失败等问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

此编译打包一直失败,中间陆陆续续尝试了好几天,最终才成功,个人尝试的是Ambari 2.5.2现阶段的最新版本。

中间踩过的N多坑没详细记录,想编译成功,记住如下几个要点:

1、单独进入每个模块目录进行编译(mvn install),都通过了,最后汇总编译ambari;(降低编译时间)

2、Ambari版本号要设定为5位数,如我的是2.5.2.0.0(四位数会因正则表达式检测不匹配报错)

mvn versions:set -DnewVersion=2.5.2.0.0  #版本号必须设为5
pushd ambari-metrics
mvn versions:set -DnewVersion=2.5.2.0.0
popd

3、修改Apache Maven的下载源,个人用的阿里云的maven源(添加了多个),淘宝的npm源;(加快下载成功率和速度);

4、编译不要老加clean,如果要执行mvn删除,可先对ambari-web/node_modules备份,执行mvn clean删除后再将备份的node_modules拷入项目,重新执行mvn install(节省时间)

5、遇到编译错误(大部分是网络下载失败),有的可手动下载对应的jar包放入对应的repository仓库,

一直提示缺少jar包出错,手动网上下载jar包,因为个人不清楚jar放入在仓库中的位置,个人采取如下命令,将jar包导入到maven的位置:

# mvn install:install-file -Dfile=/home/slide-webdavlib-2.1.jar(文件路径名)

# find ~/.m2/repository/ -name '*webdavlib*'

再将slide-webdavlib-2.1.jar拷贝到查询的目录下。


maven仓库中的某个构件如果因为网络或者其他的原因,没有下载成功或者下载被中断,将会出现一个LastUpdated的文件,这个时候,就算网络好了,也不能正常使用这个构件。可以切换到仓库的目录下执行:

find ~/.m2/repository/ -name "*.lastUpdated" -exec rm -rf {} \;


6、有的可修改pom.xml再进行编译(个人通过设置本地仓库下载,提高效率)

如下面ambari/ambari-metrics目录下的pom.xml文件:


7、有的编译一直报错,解决不了,有可能考虑版本不匹配的问题(个人全都下载目前最新的版本,同样编译过了,但多次采坑);

8、有的编译报错,重新执行编译命令错误消失了,所以至少2次出现同样的错误就说明此处存在问题

9、编译中断,重新执行编译命令,后面加上 -rf : ambari+(报错的服务)就会从没有成功的服务开始编译,前面的不会重新编译;

10、安装python环境,推荐用的是python2.6,如果用python2.7,要设置/usr/bin/python2.6文件软连接到python2.7编译环境,还要安装对应的setuptools(编译时找不到python2.6文件报过错);


最后,此编译一定要有耐心,运气不好做好持久战的准备;


个人通过如下环境编译打包成功(Ambari 2.5.2版本):

CentOS7.2

Python 2.7.5(建议安装Python2.6,/usr/bin/python2.6)

nodeJS v8.4.0

Brunch 5.3.0(npm -v

Apache Maven 3.5.0

jdk 1.8+

git

wget

gcc-c++

rpm-build-4.11.3


附编译成功后的截图(因2.5.2的ambari-web界面发生了变更,还是用老版本2.5.0进行编译,其结果如下):






<think>好的,我现在需要帮助用户了解如何编译Ambari源码。根据用户提供的引用内容,我需要整理出一个清晰的步骤指南。首先,我应该回顾用户给出的四个引用,看看它们提供了哪些关键信息。 引用[1]提到在Redhat上编译ambari-2.7.4的整个过程,包括编译准备、编译步骤和异常处理。这可能涵盖环境准备、源码修改、编译命令以及常见问题解决。引用[3]给出了具体的下载和解压命令,使用的是ambari 2.4.0版本的源码。这可能说明不同版本的Ambari编译步骤上可能有差异,需要注意版本的选择。引用[2]提到了下载node-8.6.0-linux-x64.tar.gz到特定目录,这可能是在解决依赖问题中的一个步骤,说明在编译过程中可能需要手动处理某些依赖项。引用[4]则涉及到环境变量的配置,使用mvn命令检查版本,这提示编译需要Maven,并且版本要正确配置。 接下来,我需要将这些信息整合成一个结构化的编译步骤。首先,用户需要准备环境,包括安装必要的工具如JDK、Maven、Python、RPM构建工具等。然后下载并解压源码,根据不同的版本选择对应的源码包。接着,配置环境变量,尤其是Maven的配置,确保依赖下载正确。可能还需要修改源码配置,比如调整pom.xml中的仓库地址或依赖版本。然后进行编译,使用mvn命令,但可能会遇到依赖下载问题,需要手动下载并放置到指定目录。最后,处理可能出现的异常,比如网络问题导致的依赖下载失败,或者版本不兼容的情况。 需要注意的是,用户提供的引用中有不同版本的Ambari2.7.4和2.4.0),需要指出版本差异可能带来的步骤变化。另外,手动下载依赖并放置到Maven本地仓库的步骤可能对于新手来说比较复杂,需要详细说明路径和操作方法。同时,环境变量的配置是否正确会影响编译过程,必须强调检查步骤。 用户可能遇到的问题包括依赖下载慢或失败、环境配置错误、版本不兼容等。需要提前在步骤中提醒用户注意这些点,并在常见问题部分给出解决方案,比如更换Maven镜像源,手动下载依赖,检查环境变量等。 最后,生成的相关问题应该围绕编译过程中可能遇到的挑战、不同版本的编译差异、环境配置的重要性以及编译后的安装步骤展开,帮助用户全面了解整个流程。</think>### Ambari源码编译步骤指南 #### 一、环境准备 1. **系统要求**:需基于Redhat/CentOS系统,建议使用干净的环境以减少依赖冲突[^1]。 2. **安装基础工具**: ```bash yum install -y git tar gcc make rpm-build python-devel openssl-devel ``` 3. **配置Java与Maven**: - 安装JDK 1.8+并配置环境变量。 - 安装Maven 3.6+,通过`mvn --version`验证版本,并配置`~/.m2/settings.xml`使用阿里云镜像加速依赖下载[^4]。 #### 二、源码下载与解压 根据版本需求选择源码包: - **Ambari 2.7.4**:需从Apache镜像站获取(引用未提供直接链接,需用户自行搜索)。 - **Ambari 2.4.0**: ```bash wget http://archive.apache.org/dist/ambari/ambari-2.4.0/apache-ambari-2.4.0-src.tar.gz tar xfvz apache-ambari-2.4.0-src.tar.gz [^3] ``` #### 三、依赖配置与编译 1. **手动处理依赖**(若自动下载失败): - 示例:将`node-8.6.0-linux-x64.tar.gz`下载到`/root/.m2/repository/com/github/eirslett/node/8.6.0/`[^2]。 2. **编译命令**: ```bash cd ambari-{version}-src mvn -B clean install rpm:rpm -DskipTests -Dpython.ver="python>=2.6" [^1] ``` - `-DskipTests`跳过测试以加快编译速度。 - 若遇到Python版本错误,需指定`-Dpython.ver`参数。 #### 四、异常处理 1. **依赖下载失败**: - 手动下载缺失文件至Maven本地仓库对应路径。 - 检查`pom.xml`中仓库配置,可替换为国内镜像源。 2. **环境变量问题**: - 执行`source ~/.bash_profile`刷新配置[^4]。 3. **RPM打包失败**: - 确认`rpm-build`工具已安装。 #### 五、编译输出 编译成功后,RPM包生成路径: ```bash ls ambari-{version}-src/ambari-server/target/rpm/ambari-server/RPMS/noarch/ ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值