交叉编译 mysql-connector-c

下载 mysql-connector-c

复制代码
$ wget https://downloads.mysql.com/archives/get/p/19/file/mysql-connector-c-6.1.5-src.tar.gz

注意:mysql-connector 的页面有很多版本,在测试过程中发现很多默认编译有问题,其中上面的 6.1.5 的版本呢是经过测试可以编译,并交叉编译的。

解压

复制代码
$ tar -zxvf mysql-connector-c-6.1.5-src.tar.gz

编译

  • 本地编译,之所以需要先进行一次本地编译,是因为交叉编译的过程中,会用到生成的二进制文件,如果直接交叉编译,生成的二进制文件并不能在本机运行。

    cd mysql-connector-c-6.1.5-src mkdir build && cd build
    cmake .. make -j32

  • 交叉编译,这里以 aarch64 为例:

    rm CMakeCache.txt cmake -DCMAKE_C_COMPILER=aarch64-linux-gnu-gcc -DCMAKE_CXX_COMPILER=aarch64-linux-gnu-g++ -DCMAKE_INSTALL_PREFIX={PATH} -DCMAKE_PREFIX_PATH={PATH} ..
    make sudo make install

实际测试过程中,以下表格中,除了mips 都可以交叉编译成功。

注意:这里因为需要更新 CMAKE_INSTALL_PREFIX ,所以需要先删掉 CMakeCache.txt,再次 CMake 就会更新对应的路径。

|-------------|
| amd64 |
| arm64 |
| riscv64 |
| mips |
| armhf |
| armel |

NanoMQ 交叉编译规则引擎带 MySQL 版本,建立在前面的基础上,只需指定对应工具链和路径即可:

复制代码
$ cmake -DCMAKE_C_COMPILER={arch-sys}-gcc   -DCMAKE_CXX_COMPILER={arch-sys}-g++ -DCMAKE_INSTALL_PREFIX={PATH} -DCMAKE_PREFIX_PATH={PATH} ..

如果通过 deb /rpm 包安装:

  • amd64/x86-64:

    $ sudo apt install libmysqlclient-dev

  • arm

参见上面的交叉编译步骤将 build/libmysql 目录下的以下三个文件

复制代码
libmysqlclient.so  libmysqlclient.so.18  libmysqlclient.so.18.3.0

拷贝到 /lib/aarch64-linux-gnu/ 目录下,这里是以 aarch64 为例,如果不确定,可以通过:

复制代码
$ ldd $(which nanomq)

查看对应的 nanomq 链接的版本以及位置。

如果链接的是 18 则需要编译,如果是 21 则通过安装即可。

相关推荐
paopaokaka_luck11 分钟前
基于SpringBoot+Vue的酒类仓储管理系统
数据库·vue.js·spring boot·后端·小程序
用户914536330839126 分钟前
MySQL查询执行顺序:一张图看懂SQL是如何工作的
mysql
Lx35230 分钟前
MySQL物化视图:预计算查询结果的定期刷新
sql·mysql·性能优化
Lx35231 分钟前
Mysql死锁日志分析:事务逻辑冲突的排查技巧
sql·mysql·性能优化
薛晓刚1 小时前
哪个领域数据库最难替换?
数据库
RainbowSea1 小时前
14. MySQL 锁的详细说明
java·sql·mysql
芷栀夏1 小时前
基于Anything LLM的本地知识库系统远程访问实现路径
数据库·人工智能
RainbowSea1 小时前
12 MySQL 数据库其它调优策略
java·sql·mysql
软件2052 小时前
【redis使用场景——缓存——数据淘汰策略】
数据库·redis·缓存
ChinaRainbowSea2 小时前
9-2 MySQL 分析查询语句:EXPLAIN(详细说明)
java·数据库·后端·sql·mysql