【MySQL】KylinV10 ARM 服务器上编译MySQL 5.7 XtraBackup

在ARM架构服务器(如aarch64)上编译Percona XtraBackup 2.4,需先安装依赖库、处理boost库依赖,并使用CMake配置编译。

注意: 编译服务器的内存别少于8G,否则大概率编译会卡住。

1.依赖安装

编译前需安装开发工具和库依赖。以YUM包管理器为例,执行:

bash 复制代码
yum install -y cmake gcc gcc-c++ libaio libaio-devel automake autoconf bison libtool ncurses-devel libgcrypt-devel libev-devel curl-devel 

部分系统可能需额外安装crypt-devel以解决libgcrypt.h缺失问题。

2. boost库配置

Percona XtraBackup 2.4 需要Boost 1.59.0。

若系统未预装,需手动下载并指定路径:

  • 下载Boost源码:wget https://archives.boost.io/release/1.59.0/source/boost_1_59_0.tar.gz
  • 解压至指定目录(如/usr/local/boost/):tar zxf boost_1_59_0.tar.gz -C /usr/local/boost/
  • 编译时通过-DWITH_BOOST参数指向该路径。

为什么 Percona XtraBackup 2.4.28 不能使用系统自带的 Boost 1.78 ?

Percona XtraBackup 2.4.28 强制要求使用 Boost 1.59.0 而不是系统自带的 Boost 1.78,主要有以下几个原因:

API 和 ABI 兼容性问题

  • 二进制兼容性:Boost 库在不同版本间可能存在二进制接口(ABI)不兼容
  • API 变更:Boost 1.59 到 1.78 之间某些API可能发生了变化,导致编译或运行时错误
  • 内部依赖:XtraBackup 可能依赖特定版本的Boost内部实现细节
  1. 测试和验证限制
  • Percona 只在 Boost 1.59.0 上进行了全面测试和验证
  • 新版本Boost可能引入未预期的行为变化或性能差异
  1. 历史版本依赖
  • XtraBackup 2.4.28 是基于较旧的MySQL/Percona Server代码分支开发的
  • 当时开发环境使用的就是Boost 1.59.0
  1. 已知问题规避
  • 特定版本的Boost可能包含已知问题的修复或规避方案

3. 源码获取与编译

3.1. 下载源码:从Percona官方源获取2.4版本源码包(如2.4.28):

bash 复制代码
wget https://downloads.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.28/source/tarball/percona-xtrabackup-2.4.28.tar.gz

3.2. 解压并编译:

bash 复制代码
tar zxf percona-xtrabackup-2.4.28.tar.gz
cd percona-xtrabackup-2.4.28
cmake -DBUILD_CONFIG=xtrabackup_release -DWITH_MAN_PAGES=OFF  -DWITH_BOOST=/usr/local/boost
make -j$(nproc)
  • cmake阶段会检查依赖,若缺失库(如libev、cURL),需提前安装对应-devel`包。
  • make -j$(nproc)使用所有CPU核心加速编译,可根据硬件调整。

4.常见问题解决

  • Boost下载失败:若网络受限,提前下载Boost并禁用自动下载(通过-DDOWNLOAD_BOOST=1)。
  • 依赖库未找到:如提示Cannot find gcrypt.h,确保libgcrypt-devel已安装;若libev缺失,安装libev-devel
  • CMake错误:检查PATH是否包含cmake,并确认源码路径无中文或空格。

5.验证与安装

编译完成后,验证二进制文件:

bash 复制代码
make install

安装路径默认为/usr/local/xtrabackup/,可调整CMAKE_INSTALL_PREFIX自定义。

复制代码
# ll /usr/local/xtrabackup/
total 0
drwxr-xr-x 2 root root 111 Dec 22 21:35 bin
drwxr-xr-x 3 root root  20 Dec 22 21:35 lib
drwxrwxr-x 9 root root 203 Dec 22 21:35 xtrabackup-test

# ll /usr/local/xtrabackup/bin/
total 212500
lrwxrwxrwx 1 root root        10 Dec 22 21:35 innobackupex -> xtrabackup
-rwxr-xr-x 1 root root  11421640 Dec 22 21:25 xbcloud
-rwxr-xr-x 1 root root      3020 Dec 22 21:23 xbcloud_osenv
-rwxr-xr-x 1 root root   5810448 Dec 22 21:25 xbcrypt
-rwxr-xr-x 1 root root   5954856 Dec 22 21:25 xbstream
-rwxr-xr-x 1 root root 194400768 Dec 22 21:34 xtrabackup

/usr/local/xtrabackup/bin/xtrabackup  --version

xtrabackup: recognized server arguments:
/usr/local/xtrabackup/bin/xtrabackup version 2.4.28 based on MySQL server 5.7.40 Linux (aarch64) (revision id: 44a8f7b)


file /usr/local/xtrabackup/bin/xtrabackup

/usr/local/xtrabackup/bin/xtrabackup: ELF 64-bit LSB executable, ARM aarch64, version 1 (GNU/Linux), dynamically linked, interpreter /lib/ld-linux-aarch64.so.1, BuildID[sha1]=c259a4707495cdad9da6350f38a40ad0cef3d262, for GNU/Linux 3.7.0, with debug_info, not stripped

参考

boost_1_59_0

https://www.boost.org/releases/1.59.0/

Percona XtraBackup/Percona XtraBackup 2.4

https://www.percona.com/downloads

Compiling and Installing from Source Code

https://docs.percona.com/percona-xtrabackup/2.4/installation/compiling_xtrabackup.html

ARM架构下麒麟V10操作系统编译xtrabackup

https://blog.csdn.net/weixin_58090109/article/details/118493212

国产麒麟 arm 上编译安装 xtrabackup8

https://opensource.actionsky.com/20220718-xtrabackup8

MySQL 备份利器 Xtrabackup 全解析:从部署到恢复的实战指南

https://mp.weixin.qq.com/s/YWvR32KuOR6HBJAcZ2trHw

相关推荐
云水一下21 小时前
从零开始学 PHP 系列(六):MySQL 数据库与 PHP 交互——让数据真正“住”进服务器
数据库·mysql·php
代码雕刻家21 小时前
1.24.MySQL-idea中连接MySQL的基本操作
数据库·mysql·intellij-idea
炘爚21 小时前
MySQL——事务和隔离级别
数据库·mysql
小挪号底迪滴1 天前
Redis 和 MySQL 数据不一致怎么办?缓存更新策略实战
redis·mysql·缓存
the sun341 天前
数据库中间件 ShardingSphere的安装与连通性配置
mysql
翼龙云_cloud1 天前
阿里云国际代理商:如何使用RDS MySQL 构建网站数据库?
数据库·mysql·阿里云
程序猿乐锅1 天前
【 苍穹外卖day03 | 菜品管理 】
java·开发语言·数据库·mysql
云梦泽࿐้1 天前
字符串操作全攻略:格式化、切片、正则
数据库·mysql
承渊政道1 天前
【MySQL数据库学习】(MySQL表的内外连接)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
摇滚侠1 天前
mariadb-libs 被 mysql-community-libs-5.7.28-1.el7.x86_64 取代
数据库·mysql·mariadb