简介
Redis 是一个流行的内存数据库,广泛用于缓存和消息队列。为了便于在不同架构的 Linux 系统上部署 Redis,可以通过交叉编译来生成适用于不同平台的可执行文件,并打包为 .tar.gz 以便分发和直接使用。
本文介绍如何在任何 Linux 系统上交叉编译 Redis,支持多种平台架构,包括 ARM、AArch64 等。
安装编译工具
在开始编译之前,需要安装基本的编译工具和依赖。根据你使用的 Linux 发行版,以下是不同系统的安装命令:
#Debian/Ubuntu:
sudo apt update
sudo apt install build-essential tcl curl -y
#CentOS/RHEL:
sudo yum groupinstall "Development Tools" -y
sudo yum install tcl curl -y
#Fedora:
sudo dnf groupinstall "Development Tools" -y
sudo dnf install tcl curl -y
#Arch Linux:
sudo pacman -S base-devel tcl curl
这些命令会安装 GNU 编译器、make 工具以及 Redis 编译所需的 tcl 工具。
下载 Redis 源码
在安装了编译工具后可以下载 Redis 的最新源码包,本文以7.4.1为例,在终端中运行以下命令:
curl -O http://download.redis.io/releases/redis-7.4.1.tar.gz
tar -xzf redis-7.4.1.tar.gz
cd redis-7.4.1
可在http://download.redis.io/releases/ 找到所需要的版本替换下载命令
编译 Redis
通用环境
在通用的 x86_64 架构上,直接编译 Redis 的过程非常简单。进入源码目录后,运行以下命令:
如果有多个 CPU 核心,可以使用并行编译加速编译过程:
编译成功后,你可以通过 src/redis-server --version 检查 Redis 是否成功编译。
交叉编译 Redis(多架构支持)
如果需要在其他架构(如 ARM、AArch64)上运行 Redis,可以通过交叉编译来生成适用于特定平台的二进制文件。
1、安装交叉编译工具链
首先,安装对应的交叉编译工具链。根据目标架构的不同,安装以下工具:
#ARM 64 位 (AArch64):
#Debian/Ubuntu:
sudo apt install gcc-aarch64-linux-gnu
#CentOS/Fedora/RHEL:
sudo yum install gcc-aarch64-linux-gnu
#Arch Linux:
sudo pacman -S aarch64-linux-gnu-gcc
#ARM 32 位 (ARMHF):
#Debian/Ubuntu:
sudo apt install gcc-arm-linux-gnueabihf
#CentOS/Fedora/RHEL:
sudo yum install gcc-arm-linux-gnueabihf
#Arch Linux:
sudo pacman -S arm-linux-gnueabihf-gcc
#MIPS 架构:
#Debian/Ubuntu:
sudo apt install gcc-mips-linux-gnu
#CentOS/Fedora/RHEL:
sudo yum install gcc-mips-linux-gnu
2、使用交叉编译生成不同架构的 Redis
下载并解压 Redis 源码后,使用不同的交叉编译器进行编译。
#AArch64 架构(ARM 64 位)
make CC=aarch64-linux-gnu-gcc
#ARM 32 位:
make CC=arm-linux-gnueabihf-gcc
#MIPS 架构:
make CC=mips-linux-gnu-gcc
通过这样设置编译器,可以生成适用于不同平台的二进制文件。
3、检查编译结果
交叉编译完成后,你可以使用 file 命令来检查生成的二进制文件的架构:
file src/redis-server
输出结果应类似于:src/redis-server: ELF 64-bit LSB executable, ARM aarch64, version 1 (SYSV), dynamically linked, ...
此命令可以帮助你确认生成的可执行文件是否为目标架构。
打包 Redis 为 .tar.gz
编译完成后,我们可以将 Redis 可执行文件和配置文件打包,以便在其他机器上直接解压使用。
- 创建一个新的目录来存放编译后的 Redis 可执行文件和配置文件
- 将编译生成的可执行文件复制到 bin 目录
- 复制默认的 redis.conf 配置文件到 conf 目录
- 最后,将 redis-7.4.1-dist 目录打包成 .tar.gz 文件
mkdir -p redis-7.4.1-dist/bin mkdir -p redis-7.4.1-dist/conf
cp src/redis-server src/redis-cli src/redis-benchmark src/redis-check-aof src/redis-check-rdb redis-7.4.1-dist/bin/
cp redis.conf redis-7.4.1-dist/conf/
tar -czvf redis-7.4.1-dist.tar.gz redis-7.4.1-dist
现在已经生成了一个打包的 Redis 版本,方便在其他机器上解压并直接使用。
在其他机器上解压并运行 Redis
将生成的 .tar.gz 文件复制到目标机器后,解压并运行 Redis。通过 redis-cli,可以与 Redis 服务器进行交互
tar -xzf redis-7.4.1-dist.tar.gz cd redis-7.4.1-dist ./bin/redis-server ./conf/redis.conf
./bin/redis-cli
总结
通过本文介绍的步骤,你可以在任何 Linux 系统上编译 Redis,并且通过交叉编译生成适用于不同架构(如 ARM 和 MIPS)的二进制文件。这种方法特别适用于需要在多平台部署 Redis 的场景,通过打包成 .tar.gz,你可以轻松复制到其他机器上进行解压和使用。