树莓派编译hadoop 3.2.1源码,错误:undefined reference to `__atomic_load_8‘

最近在研究树莓派编译hadoop源码,坑非常非常多。。。

1、编译过程中 HADOOP-HDFS-NATIVE-CLIENT 错误:

错误主要是在执行一下指令时发生的:

/usr/bin/c++   -g -O2 -Wall -pthread -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -Wall -Wextra -pedantic -std=c++11 -g -fPIC -fno-strict-aliasing -Wno-missing-field-initializers    -rdynamic CMakeFiles/hdfspp_mini_dfs_smoke_hdfspp_test_shim_static.dir/hdfspp_mini_dfs_smoke.cc.o  -o hdfspp_mini_dfs_smoke_hdfspp_test_shim_static -Wl,-rpath,/opt/protobuf/protobuf-2.5.0/lib:/opt/jdk/jdk1.8.0_181/jre/lib/arm/server libhdfspp_test_shim_static.a ../lib/fs/libfs.a ../lib/reader/libreader.a ../lib/rpc/librpc.a ../lib/proto/libproto.a ../lib/common/libcommon.a ../lib/connection/libconnection.a ../third_party/gmock-1.7.0/libgmock_main.a /opt/protobuf/protobuf-2.5.0/lib/libprotobuf.so -pthread -lssl -lcrypto ../../libhdfs-tests/libnative_mini_dfs.a /opt/jdk/jdk1.8.0_181/jre/lib/arm/server/libjvm.so -lsasl2 -ldl 
 

而错误显示的是 undefined reference to `__atomic_load_8'。

其实这主要是由于cmake编译参数与实际环境不同导致的。树莓派最新的是c++ 8,而通过以上代码可以看到用的是c++11,所以难免会遇到一些问题。

解决方法:

参考了国外网站,我在 /home/pi/Desktop/hadoop-3.2.1-src/hadoop-hdfs-project/hadoop-hdfs-native-client/src/main/native/libhdfspp/CMakeLists.txt 文件中的CMAKE_CXX_FLAG中添加了 -latomic,再运行mvn,该报错不再出现。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值