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

相关推荐
sunnyday04264 分钟前
MyBatis XML映射文件中的批量插入和更新
xml·java·mysql·mybatis
浪九天9 分钟前
Orcale、MySQL中参数类型的详解和运用场景(不带示例)
数据库·mysql·oracle
程序员阿鹏12 分钟前
jdbc批量插入数据到MySQL
java·开发语言·数据库·mysql·intellij-idea
计算机毕设指导62 小时前
基于SpringBoot的城乡商城协作系统【附源码】
java·spring boot·后端·mysql·spring·tomcat·maven
橘猫云计算机设计2 小时前
基于Django的购物商城平台的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·django
2501_903238652 小时前
Spring Boot日志配置与环境切换实战
数据库·spring boot·后端·个人开发
梓沂2 小时前
审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空
数据库·sql·dba
Smile丶凉轩3 小时前
数据库面试知识点总结
数据库·c++·mysql
RainbowSea4 小时前
9-1. MySQL 性能分析工具的使用——last\_query\_cost,慢查询日志
数据库·sql·mysql
Sui_Network4 小时前
Sui 如何支持各种类型的 Web3 游戏
大数据·数据库·人工智能·游戏·web3·区块链