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

相关推荐
随记1234 分钟前
Microsoft SQL Server Management 一键删除数据库所有外键
数据库·sql·sqlserver
韶博雅18 分钟前
mysql表类型查询
android·数据库·mysql
nangonghen20 分钟前
JAVA程序实现mysql读写分离并在kubernetes中演示
java·mysql·mybatis·读写分离
小wanga35 分钟前
【MySQL】索引特性
android·数据库·mysql
wpp03031 小时前
GaussDB SQL查询与子查询:从入门到性能调优
数据库
云之兕1 小时前
MyBatis 如何使用
数据库·mybatis
TDengine (老段)1 小时前
TDengine 语言连接器(R语言)
大数据·数据库·物联网·r语言·时序数据库·tdengine·iotdb
日行月白1 小时前
Day14:关于MySQL的索引——创、查、删
数据库·mysql
拄杖忙学轻声码2 小时前
shardingsphere-jdbc集成Seata分布式事务
mysql·spring cloud
神仙别闹2 小时前
基于javaEE+jqueryEasyUi+eclipseLink+MySQL的课程设计客房管理信息系统
mysql·java-ee·课程设计