`
扬州老鬼
  • 浏览: 306534 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

rpmbuild淘宝datax代码,File not found问题解决

 
阅读更多
原创,转载请注明出处。

首先批评一下:淘宝开源了数据抽取的工具datax,但是他在开源之后后续技术支持简直惨不忍睹。技术文档完全不是一个业内技术航母应有的范儿,文档水准简直业余。个人觉得,你既然支持开源,起码也要尊重开源,随便搞了一个文档就想糊弄,要知道这个使用者带来很大问题,并花费很多时间。

在RHEL 6.2 rpmbulid datax源码包,出现报错信息:

[root@Hadoop rpm]# rpmbuild -ba t_dp_datax_engine.spec
。。。。。
Processing files: t_dp_datax_engine-1.0.0-1.noarch
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/bin
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/conf
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/engine
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/common
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/libs
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/logs
error: File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/jobs


RPM build errors:
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/bin
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/conf
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/engine
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/common
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/libs
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/logs
    File not found: /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64/home/taobao/datax/jobs


我知道这是rhel 6.2的rpmbuild的buildroot的目录和rhel 5不一样。上述问题的解决方法:
修改t_dp_datax_engine.spec。
[root@Hadoop rpm]# cat t_dp_datax_engine.spec
summary: engine provides core scheduler and data swap storage for DataX 
Name: t_dp_datax_engine
Version: 1.0.0
Release: 1
Group: System
License: GPL
AutoReqProv: no 
BuildArch: noarch

%define dataxpath  /home/taobao/datax //改成%{buildroot}/home/taobao/datax
%define vdataxpath /home/taobao/datax //添加,其中vdataxpath下面要用

%description
DataX Engine provides core scheduler and data swap storage for DataX 

%prep
cd ${OLDPWD}/../
export LANG=zh_CN.UTF-8
ant dist

%build

%install
dos2unix ${OLDPWD}/../release/datax.py

mkdir -p %{dataxpath}/bin
mkdir -p %{dataxpath}/conf
mkdir -p %{dataxpath}/engine
mkdir -p %{dataxpath}/common
mkdir -p %{dataxpath}/libs
mkdir -p %{dataxpath}/jobs
mkdir -p %{dataxpath}/logs

cp ${OLDPWD}/../jobs/sample/*.xml %{dataxpath}/jobs
cp ${OLDPWD}/../release/*.py %{dataxpath}/bin/

cp -r ${OLDPWD}/../conf/*.properties %{dataxpath}/conf
cp -r ${OLDPWD}/../conf/*.xml %{dataxpath}/conf

cp -r ${OLDPWD}/../build/engine/*.jar %{dataxpath}/engine

cp -r ${OLDPWD}/../build/common/*.jar %{dataxpath}/common
cp ${OLDPWD}/../c++/build/libcommon.so %{dataxpath}/common

cp -r ${OLDPWD}/../libs/commons-io-2.0.1.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/commons-lang-2.4.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/dom4j-2.0.0-ALPHA-2.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/jaxen-1.1-beta-6.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/junit-4.4.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/log4j-1.2.16.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/slf4j-api-1.4.3.jar %{dataxpath}/libs
cp -r ${OLDPWD}/../libs/slf4j-log4j12-1.4.3.jar %{dataxpath}/libs

%post
chmod -R 0777 %{dataxpath}/jobs //改成chmod -R 0777 %{vdataxpath}/jobs
chmod -R 0777 %{dataxpath}/logs //改成chmod -R 0777 %{vdataxpath}/logs

%files
%defattr(0755,root,root)
%{dataxpath}/bin // 改成%{vdataxpath}/bin
%{dataxpath}/conf //改成%{vdataxpath}/conf
%{dataxpath}/engine //改成%{vdataxpath}/engine 
%{dataxpath}/common //改成%{vdataxpath}/common 
%{dataxpath}/libs //改成%{vdataxpath}/libs 
%attr(0777,root,root) %dir %{dataxpath}/logs //改成%attr(0777,root,root)
 %{vdataxpath}/logs
%attr(0777,root,root) %dir %{dataxpath}/jobs //改成 %attr(0777,root,root)   %{vdataxpath}/jobs


%changelog
* Fri Aug 20 2010 meining 
- Version 1.0.0



编译结果:
[root@Hadoop rpm]# rpmbuild -ba  t_dp_datax_engine.spec
。。。
Processing files: t_dp_datax_engine-1.0.0-1.noarch
Checking for unpackaged file(s): /usr/lib/rpm/check-files /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64
Wrote: /root/rpmbuild/SRPMS/t_dp_datax_engine-1.0.0-1.src.rpm
Wrote: /root/rpmbuild/RPMS/noarch/t_dp_datax_engine-1.0.0-1.noarch.rpm
Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.y3UwSl
+ umask 022
+ cd /root/rpmbuild/BUILD
+ /bin/rm -rf /root/rpmbuild/BUILDROOT/t_dp_datax_engine-1.0.0-1.x86_64
+ exit 0


至于rpmbuil的SPEC文件的定义参数含义,可以参考:
http://fedoraproject.org/wiki/How_to_create_an_RPM_package#.25install_section


以上是我解决的问题。还有一个我没能解决的问题是:
编译符合我环境的oraclewriter。
datax的文档是怎么写的:
由于Oracle最终通过jni调用oci机制导入数据, 默认情况下,DataX提供基于Intel x86_64 liboraclewriter.so包。如果你使用的平台硬件和默认情况不匹配,需要编译oraclewriter C++代码,liboraclewriter.so需要libiconv库的支持,请先检查该库是否存在。具体编译过程如下:
1) 进入 DataX源码中的c++/src/oracledumper/src/ 目录
2) 输入make命令即可编译
3) 将当前目录下编译完成的liboraclewriter.so 拷贝至/home/taobao/datax/plugins/目录下,覆盖默认的liboraclewriter.so即可

在rhel5.4的基础上面我进行了编译,虽然也是OK的,但是其中需要注意的是:
*这一步是要在oracle软件安装的那一台机器上上面去编译,并且环境变量中指定ORACLE_HOME
*要指明LD_LIBRARY_PATH
*其中还要安装libiconv库。

但是在我rhel6.2的上面上,怎么都不编译成功。
我做了以下修改trunk/c++/src/oracledumper/src/Makefile,修改的原因他是找不到jni.h.
修改如下:
[root@Hadoop src]# cat Makefile
INCLUDE=-I../include //添加 -I${ORACLE_HOME}/jdk/include -I${ORACLE_HOME}/jdk/include/linux
LIBS=-lclntsh -liconv -L../lib -L${ORACLE_HOME}/lib -L../../../../libs/
CC=g++
OBJS=liboraclewriter.so
CFLAGS=-shared -fPIC -Wl,-rpath=/home/taobao/datax/libs
CPP=common.cpp dumper.cpp oradumper.cpp strsplit.cpp com_taobao_datax_plugins_writer_oraclewriter_OracleWriterJni.cpp

OBJS: $(CPP)
	$(CC) $(INCLUDE) -o $(OBJS) $(CPP) $(CFLAGS) $(LIBS)
clean:
	rm -rf $(OBJS)



可是最终我还是卡在这里了:
[root@Hadoop src]# make
g++ -I../include -I/home/oracle/database/product/10.2.0/db_1/jdk/include -I/home/oracle/database/product/10.2.0/db_1/jdk/include/linux  -o liboraclewriter.so common.cpp dumper.cpp oradumper.cpp strsplit.cpp com_taobao_datax_plugins_writer_oraclewriter_OracleWriterJni.cpp -shared -fPIC -Wl,-rpath=/home/taobao/datax/libs -lclntsh -liconv  -L../lib -L/home/oracle/database/product/10.2.0/db_1/lib -L../../../../libs/ 
oradumper.cpp: In member function ?.irtual void OraDumper::RunDump(const char*)?.
oradumper.cpp:305: error: invalid conversion from ?.onst char*?.to ?.har*?
oradumper.cpp:312: warning: deprecated conversion from string constant to ?.har*?
oradumper.cpp:314: warning: deprecated conversion from string constant to ?.har*?
make: *** [OBJS] Error 1

这我就无能无力了,cpp代码不是我强项。

现在只能希望在rhel5.4的版本生成的liboraclewriter.so在rhel6.2上面能用。不然就得联系淘宝的开发人员了。
我的总结,淘宝datax对目前rhel6的支持还不够,希望跟他们联系了,能解决这个问题,晚上这个很好开源软件。

最后还是对淘宝表示敬意,希望各方面都做的像一个领导者。






4
1
分享到:
评论
3 楼 wxcking 2015-06-19  
引用
引用
[u][i][b][b][u]
引用
[list]
[*][img][url][flash=200,200][*][*][*]
[flash=200,200][url][img][list]
[*]
引用
[u][i][b][b][b][b][b][b][i][u]
引用
[list]
[*][*][img][url][flash=200,200][*][*]
[*][*]
[*][*]
[/flash][/url][/img]| [*]|[*][/list][/u][/i][/b][/b][/b][/b][/b][/b][/i][/u]|
  • |[/list][/img][/url][/flash]|
  • [/flash][/url][/img][/list]
    [/u][/b]        [/b][/i][/u]
    2 楼 SoldierBandit 2013-11-18  
    话说,这玩意可以在windows平台上运行吗?你们发的完全看不明白的干活。
    1 楼 xiaohai4516 2013-10-12  
    297         const char *end = NULL;  我在前面添加了一个const

    编译这个文件的时候 注意先安装iconv库 http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz  就可以编译成功了

    相关推荐

      64位linux 编译c提示gnu/stubs-32.h:No such file or directory的解决方法

      今天,我们就来探讨解决这个问题的方法。 首先,让我们了解问题的出现原因。在编译C语言程序时,编译器会自动包含gnu/stubs.h头文件,而这个头文件中又包含gnu/stubs-32.h文件。但是,在64位Linux系统下,gnu/stubs...

      DATAX安装与开发

      - 使用root权限运行命令:`rpmbuild --bat_dp_datax_engine.spec` - 修改`t_dp_datax_engine.spec`文件: - 更改`%definedataxpath`为`%definedataxpath {buildroot}/home/taobao/datax` - 添加`%definevdataxpath...

      rpmbuild-V1.0.3.zip

      3. **rpmbuild工具**:rpmbuild是RPM工具集的一部分,用于从SPEC文件和源代码构建RPM软件包。它的常用命令包括`rpmbuild -ba`(构建所有阶段)和`rpmbuild -rebuild`(重建已有的RPM源码包)。 4. **RPM的元数据**...

      rpmbuild的一个例子

      在 `%setup` 部分,`rpmbuild`会解压这个源代码包到一个工作目录中。 3. **编译源代码**:在 `%build` 部分,我们编写用于编译源代码的命令。`rpmbuild`会在这个阶段执行这些命令,将源代码编译成可执行文件。 4. ...

      ARM架构和X86_64架构rpmbuild制作openssh和openssl的rpm包

      2. **创建RPM构建目录结构**:设置`~rpmbuild`目录结构,包括`SPECFILE`、`SRPM`、`BUILD`、`BUILDROOT`、`RPMS`和`SOURCES`等子目录。 3. **编写SPEC文件**:SPEC文件是描述如何构建RPM包的蓝图,包含版本信息、...

      rpmbuild-hello

      标题“rpmbuild-hello”和描述“rpmbuild-hello-1.0.tar.gz”表明我们正在讨论一个使用`rpmbuild`工具构建的RPM软件包,该软件包的名称是“hello”,版本号为1.0,源代码被压缩在名为“hello-1.0.tar.gz”的文件中。...

      rpmbuild-demo工程

      一个rpm build打包的示例工程,下载完成后可以解压成/home/wang/rpmbuild目录,然后到SPEC目录中执行rpmbuild -ba dteworker-client.spec 即可完成打包

      cenos fuse-exfat

      2. 解压源代码包,使用`rpmbuild`命令进行编译和构建RPM包。 3. 安装生成的RPM包,使用`yum install`或`dnf install`命令(取决于你的CentOS版本)。 4. 接下来,可能需要添加用户到`fuse`组,因为挂载文件系统通常...

      RPM包rpmbuild SPEC文件深度说明

      RPM包rpmbuild SPEC文件深度说明 学习如何写spec脚本制作rpm包

      uic下载 qtopia-free-2.2.0/bin/uic:命令未找到

      uic下载 qtopia-free-2.2.0/bin/uic:命令未找到 解决:将此文件复制到qtopia-free-2.2.0/qt2/bin目录下

      rpmbuild spec打包指南

      rpmbuild会按照spec文件的指示,处理源代码,生成RPM包。此外,还要注意处理好软件的依赖关系,确保用户在安装时能够顺利获取并安装所有必要的依赖库。 文档还可能涵盖了测试、签名、发布RPM包的步骤,以及如何贡献...

      利用rpmbuild制作rpm包的总结1

      整个过程就是这样,通过`rpmbuild`工具,你可以将源代码打包成符合RPM规范的软件包,便于在支持RPM的Linux系统上分发和管理。记住,这只是一个基础的示例,实际的RPM包构建可能涉及更复杂的配置,例如设置编译选项、...

      rpmbuild 打成成功的demoe testrpm

      在描述中提到,如果你在练习CentOS与Qt的RPM打包时感到困惑,可以通过这个演示来启动你的打包旅程,这暗示了我们将涉及如何为Qt应用程序准备源代码、配置`spec`文件以及运行`rpmbuild`命令。 首先,我们需要一个Qt...

      arch-rpmbuild:Dockerfile 在 Arch Linux 下使用 rpmbuild

      arch-rpmbuild Dockerfile 在 Arch Linux 下使用 rpmbuild

      anacheAnt-ImageMagic-rpmbuild-arm.zip

      标题中的"anacheAnt-ImageMagic-rpmbuild-arm.zip"指示了这是一个针对ARM架构的RPM打包文件,其中包含了Apache Ant和ImageMagick两个重要的软件工具。让我们深入了解一下这两个工具以及它们在ARM架构上的应用。 ...

      RPM打包技术与典型SPEC文件分析

      例如,`rpmbuild -ba specfile.spec`会执行全部构建步骤。 中文的`rpmbuild`手册页对于初学者尤其有帮助,因为它提供了本地化的详细说明,解释了每个选项和宏的作用,使开发者更容易理解和掌握RPM打包技术。 总结...

      ceph-fs-rpm-build

      Summary: Ceph File System RPM package License: LGPLv2+ Source0: %{name}-%{version}.tar.gz ``` 这里,`ceph_version`是一个宏,需要在构建时替换为实际的Ceph版本号。 接着,我们需要下载Ceph源代码并根据`...

    Global site tag (gtag.js) - Google Analytics