交叉编译 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 则通过安装即可。

相关推荐
J超会运1 天前
OpenEuler系统MySQL故障排查终极指南
mysql
瀚高PG实验室1 天前
使用hgdbdeveloper开发工具导出数据后在异机恢复时报错
数据库·瀚高数据库
百结2141 天前
PostgreSQL 初体验
数据库·postgresql
ward RINL1 天前
Redis 安装及配置教程(Windows)【安装】
数据库·windows·redis
bingHHB1 天前
金蝶云星空旗舰版 × 赛狐ERP:亚马逊卖家业财一体化的最后一公里
运维·数据库·集成学习
Nontee1 天前
Redis高可用架构解析
数据库·redis·架构
淼淼爱喝水1 天前
DVWA SQL 注入(Medium/High 级别)过滤绕过与防范实验(超详细图文版)
数据库·sql·网络安全
csdn_aspnet1 天前
MySQL主从延迟根因诊断法,从网络、IO、SQL到参数,系统化定位高并发下的同步瓶颈
数据库·mysql·主从
SHANGHAILINGEN1 天前
NM | FungAMR数据库,一键筛查真菌耐药基因!
数据库
Deryck_德瑞克1 天前
【已解决】MySQL连接出错 1045 - Access denied for user ‘root‘@‘::1‘
android·mysql·adb