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

相关推荐
程序新视界6 小时前
MySQL中什么是回表查询,如何避免和优化?
mysql
薛定谔的算法11 小时前
phoneGPT:构建专业领域的检索增强型智能问答系统
前端·数据库·后端
Databend12 小时前
Databend 亮相 RustChinaConf 2025,分享基于 Rust 构建商业化数仓平台的探索
数据库
得物技术13 小时前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
Java水解14 小时前
【MySQL】从零开始学习MySQL:基础与安装指南
后端·mysql
Raymond运维18 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
沢田纲吉18 小时前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
RestCloud1 天前
SQL Server到Hive:批处理ETL性能提升30%的实战经验
数据库·api
RestCloud1 天前
为什么说零代码 ETL 是未来趋势?
数据库·api
ClouGence1 天前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库