原创文章,转载请正确注明本文原始URL及作者。

今天要编译一个zookeeper的C接口,要编译一个TK1版本。

事情经过这这样的:
原来用的是zookeeper-3.4.6版本,但是源码中有个函数是汇编代码,指令不兼容,编译不过。
这里折腾了好久,还准备读懂代码写个C代码替换,结果官方已经修改了这个问题了。

下载了源码包 zookeeper-trunk.zip

里面没有configure,需要生成configure ,按照README和INSTALL来做。

这里折腾了好久,又是需要ant,又是需要autoreconf的,而且TK1上还没有这些工具,在PC上也总有错。

有到网上找了个版本
zookeeper-3.5.1-alpha.tar.gz
里面带有configure,哈哈,好用,直接放到TK1板子上编译出了 libzookeeper_mt 。
看来trunk上的代码需要大神才能编译啊,没有带configure,需要autoconf,一般人不会用。

然后把 libzookeeper_mt 考到我的交叉编译的虚拟机上,编译我的mq,结果报错:
Linking CXX executable ../bin/linux_arm_tk1/testor
/usr/lib/gcc/arm-linux-gnueabihf/4.6/../../../../arm-linux-gnueabihf/bin/ld: warning: ld-linux.so.3, needed by /usr/lib/gcc/arm-linux-gnueabihf/4.6/libstdc++.so, not found (try using -rpath or -rpath-link)
/home/xxx...xxx/libzookeeper_mt.so: undefined reference to `__poll_chk@GLIBC_2.16'
collect2: ld 返回 1

是因为 libzookeeper_mt 从TK1板子上编译,而现在我从虚拟机编译依赖这个库,估计是版本问题。
在TK1上用make编译是可以的,但我们的工程是cmake组织的,编译都是用的虚拟机,看来还是需要从虚拟机重新编译个 libzookeeper_mt 。

从虚拟机交叉编译zookeeper
./configure --host=arm-linux-gnueabihf
报错:
checking that generated files are newer than configure... done
configure: creating ./config.status
./config.status: line 2300: syntax error: unexpected end of file
这个错误真是太奇怪了,每次自动生成这个文件,还生成的有错。

最后无怒了,不用它生成了,我自己从命令行编译吧。

最后是这样解决了问题:
在TK1上有编译一遍,复制出编译过程中的编译选项。
找到TK1生成的静态库,把.o列表显示出来。
然后自己在虚拟机中写脚本,按照它的编译选项编译.o对应的源码,终于可以用了!

原创文章,转载请正确注明本文原始URL及作者。

交叉编译zookeeper的C库的更多相关文章

  1. Linux学习笔记——怎样在交叉编译时使用共享库

    0.前言     在较为复杂的项目中会利用到交叉编译得到的共享库(*.so文件).在这样的情况下便会产生下面疑问,比如:     [1]交叉编译时的共享库是否须要放置于目标板中,假设须要放置在哪个文件 ...

  2. 交叉编译多平台 FFmpeg 库并提取视频帧

    原文地址: 交叉编译多平台 FFmpeg 库并提取视频帧 交叉编译多平台 FFmpeg 库并提取视频帧 本文档适用于 x86 平台编译 armeabi.armeabi-v7a.arm64-v8a.x8 ...

  3. 交叉编译多平台 FFmpeg 库并提取视频帧(转)

    交叉编译多平台 FFmpeg 库并提取视频帧 转  https://www.cnblogs.com/leviatan/p/11142579.html 本文档适用于 x86 平台编译 armeabi.a ...

  4. C/C++ 跨平台交叉编译、静态库/动态库编译、MinGW、Cygwin、CodeBlocks使用原理及链接参数选项

    目录 . 引言 . 交叉编译 . Cygwin简介 . 静态库编译及使用 . 动态库编译及使用 . MinGW简介 . CodeBlocks简介 0. 引言 UNIX是一个注册商标,是要满足一大堆条件 ...

  5. Linux学习笔记——如何使用共享库交叉编译

    0.前言     在较为复杂的项目中会利用到交叉编译得到的共享库(*.so文件).在这样的情况下便会产生下面疑问,比如:     [1]交叉编译时的共享库是否须要放置于目标板中,假设须要放置在哪个文件 ...

  6. 基于ZooKeeper的分布式锁和队列

    在分布式系统中,往往需要一些分布式同步原语来做一些协同工作,上一篇文章介绍了Zookeeper的基本原理,本文介绍下基于Zookeeper的Lock和Queue的实现,主要代码都来自Zookeeper ...

  7. ZooKeeper开发手册中文翻译(转)

    本文Github地址:https://github.com/sundiontheway/zookeeper-guide-cn 本文假设你已经具有一定分布式计算的基础知识.你将在第一部分看到以下内容: ...

  8. NeuSoft(1)构建嵌入式交叉编译环境

    操作系统版本:ubuntu 12.04 内核名称:Linux 内核发行版:3.2.0-generic 内核版本:#50-Ubuntu SMP Mon Sep 12 21:18:14 UTC 2011 ...

  9. ZooKeeper学习第六期---ZooKeeper机制架构

    一.ZooKeeper权限管理机制 1.1 权限管理ACL(Access Control List) ZooKeeper 的权限管理亦即ACL 控制功能,使用ACL来对Znode进行访问控制.ACL的 ...

随机推荐

  1. Qt QListWidget实现图片缩略图列表

    转载:v_xchen_v 目标: 将本机中的多张图片以缩略图的形式显示在列表中 环境: 我们已经做好了菜单栏和文件选择对话框.参考:http://blog.csdn.net/v_xchen_v/art ...

  2. 补充appium -api

    //锁屏 driver.lockScreen(2); //判断是否锁屏 driver.isLocked(); //截屏并保存至本地 File screen = driver.getScreenshot ...

  3. jmap、jstack、jps无法连接jvm解决办法

    转载 http://blog.51cto.com/zhangshaoxiong/1310166 一.背景 在对线上服务器的java应用dump操作时发现,以下报错,不能dump.jps也获取不到jav ...

  4. Eureka与ZooKeeper 的比较(转)

    https://www.cnblogs.com/zgghb/p/6515062.html Eureka的优势 1.在Eureka平台中,如果某台服务器宕机,Eureka不会有类似于ZooKeeper的 ...

  5. Hbase设置多个hmaster

    Hbase设置多个hmaster https://www.cnblogs.com/prayer21/p/4866673.html

  6. 知识点:Mysql 基本用法之事务

    事务 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 事务实例: create table user( id int primar ...

  7. 小程序API录音 微信录音后 Silk格式转码MP3

    http://www.cnblogs.com/wqh17/p/6911748.html

  8. Mongodb集群搭建之 Replica Set

    Mongodb集群搭建之 Replica Set Replica Set 中文翻译叫做副本集,不过我并不喜欢把英文翻译成中文,总是感觉怪怪的.其实简单来说就是集群当中包含了多份数据,保证主节点挂掉了, ...

  9. FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. com/mongodb/util/JSON

    问题: 将MongoDB数据导入Hive,按照https://blog.csdn.net/thriving_fcl/article/details/51471248文章,在hive建外部表与mongo ...

  10. courator - create

    0. retry policy RetryPolicy retryPolicy = new ExponentialBackoffRetry(3000,3); 1. client 1) recipes ...