news 2026/4/18 6:22:02

CentOS 编译安装 Redis 6.2.1 并部署多实例(单服务器)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CentOS 编译安装 Redis 6.2.1 并部署多实例(单服务器)

一、前言

本文基于 CentOS 系统,完整记录 Redis 6.2.1 手动编译安装过程(解决 jemalloc 编译报错),并实现单服务器部署两个独立 Redis 实例(6379/6380),无需创建多个 Linux 系统,核心是通过「配置隔离」实现实例独立运行。

二、环境准备

  • 系统:CentOS(7/8 均可)
  • 权限:root 用户
  • 依赖:GCC 编译工具(Redis 基于 C 语言开发)

三、Redis 6.2.1 编译安装(解决 jemalloc 报错)

3.1 下载并解压 Redis 安装包

# 1. 创建安装目录(自定义,本文用 /root/lamp) mkdir -p /root/lamp && cd /root/lamp # 2. 安装 wget(若未安装) yum install -y wget # 3. 下载 Redis 6.2.1 源码包 wget http://download.redis.io/releases/redis-6.2.1.tar.gz # 4. 解压压缩包 tar -zxvf redis-6.2.1.tar.gz && cd redis-6.2.1

3.2 安装 GCC 编译工具

yum install -y gcc

3.3 编译安装(解决 jemalloc 报错)

直接make可能出现以下报错:

In file included from adlist.c:34:
zmalloc.h:5B:31: warning: jemalloc/jemalloc.h: No such file or directory
zmalloc.h:55:2: error: #error "Newer version of jemalloc required"
make: *** [adlist.ol Error 1

解决方法:清理编译残留 + 指定系统 malloc 编译

# 1. 清理之前的编译残留 make distclean # 2. 重新编译(指定使用系统 libc 代替 jemalloc) make MALLOC=libc # 3. 执行安装(将 redis-server/redis-cli 等命令安装到系统路径) make install

3.4 验证安装

# 检查 redis-server 路径 which redis-server # 输出:/usr/local/bin/redis-server # 检查版本 redis-server -v # 输出:Redis v6.2.1

四、部署两个独立 Redis 实例(6379/6380)

核心思路:为每个实例配置「独立端口、配置文件、数据目录、日志文件」,实现隔离运行。

4.1 创建实例隔离目录

# 创建实例1(6379)、实例2(6380)的配置/数据/日志目录 mkdir -p /root/lamp/redis_instance/{6379,6380}/{conf,data,log} # 复制默认配置文件到实例目录 cp /root/lamp/redis-6.2.1/redis.conf /root/lamp/redis_instance/6379/conf/redis_6379.conf cp /root/lamp/redis-6.2.1/redis.conf /root/lamp/redis_instance/6380/conf/redis_6380.conf

4.2 修改实例配置文件(核心:隔离关键参数)

4.2.1 实例 1(6379)配置:/root/lamp/redis_instance/6379/conf/redis_6379.conf

编辑文件,修改以下关键项(其余保持默认):

# 端口(默认6379) port 6379 # 守护进程启动(后台运行,避免终端关闭停服务) daemonize yes # 数据存储目录 dir /root/lamp/redis_instance/6379/data # 日志文件路径 logfile "/root/lamp/redis_instance/6379/log/redis_6379.log" # PID文件(避免冲突) pidfile "/var/run/redis_6379.pid" # 关闭保护模式(测试环境,生产环境建议设密码) protected-mode no # 可选:设置访问密码 requirepass "redis6379"

批量替换脚本:

#无身份校验 sed -i -e 's/^port .*/port 6379/' -e 's/^daemonize .*/daemonize yes/' -e 's/^dir .*/dir \/root\/lamp\/redis_instance\/6379\/data/' -e 's/^logfile .*/logfile "\/root\/lamp\/redis_instance\/6379\/log\/redis_6379.log"/' -e 's/^pidfile .*/pidfile "\/var\/run\/redis_6379.pid"/' -e 's/^protected-mode .*/protected-mode no/' /root/lamp/redis_instance/6379/conf/redis_6379.conf

替换前建议先备份:

# 备份6379配置 cp /root/lamp/redis_instance/6379/conf/redis_6379.conf /root/lamp/redis_instance/6379/conf/redis_6379.conf.bak

检查替换结果:

# 验证6379实例配置 grep -E 'port|daemonize|dir|logfile|pidfile|protected-mode|requirepass' /root/lamp/redis_instance/6379/conf/redis_6379.conf
4.2.2 实例 2(6380)配置:/root/lamp/redis_instance/6380/conf/redis_6380.conf

核心修改端口和路径,其余同实例 1:

# 端口改为6380(唯一) port 6380 daemonize yes # 实例2数据目录 dir /root/lamp/redis_instance/6380/data # 实例2日志文件 logfile "/root/lamp/redis_instance/6380/log/redis_6380.log" # 实例2 PID文件 pidfile "/var/run/redis_6380.pid" protected-mode no # 实例2密码(可不同) requirepass "redis6380"

批量替换脚本:

# 6380实例配置自动替换脚本 sed -i -e 's/^port .*/port 6380/' -e 's/^daemonize .*/daemonize yes/' -e 's/^dir .*/dir \/root\/lamp\/redis_instance\/6380\/data/' -e 's/^logfile .*/logfile "\/root\/lamp\/redis_instance\/6380\/log\/redis_6380.log"/' -e 's/^pidfile .*/pidfile "\/var\/run\/redis_6380.pid"/' -e 's/^protected-mode .*/protected-mode no/' /root/lamp/redis_instance/6380/conf/redis_6380.conf

替换前建议先备份:

# 备份6380配置 cp /root/lamp/redis_instance/6380/conf/redis_6380.conf /root/lamp/redis_instance/6380/conf/redis_6380.conf.bak

检查替换结果:

grep -E 'port|daemonize|dir|logfile|pidfile|protected-mode' /root/lamp/redis_instance/6380/conf/redis_6380.conf

4.3 启动两个 Redis 实例

# 启动实例1(6379) redis-server /root/lamp/redis_instance/6379/conf/redis_6379.conf # 启动实例2(6380) # 方式1:新开终端(Alt+F2 切换到 tty2)执行 redis-server /root/lamp/redis_instance/6380/conf/redis_6380.conf # 方式2:直接在当前终端后台启动(推荐) redis-server /root/lamp/redis_instance/6380/conf/redis_6380.conf

4.4 验证实例运行状态

4.4.1 查看 Redis 进程
ps -ef | grep redis-server
4.4.2 连接实例测试隔离性
  • 连接 6379 实例:

    redis-cli -p 6379 127.0.0.1:6379> auth redis6379 # 输入密码(若设置) OK 127.0.0.1:6379> set test6379 "hello6379" OK 127.0.0.1:6379> get test6379 "hello6379"
  • 连接 6380 实例:

    redis-cli -p 6380 127.0.0.1:6380> auth redis6380 OK 127.0.0.1:6380> get test6379 # 查不到6379的键,隔离成功 (nil) 127.0.0.1:6380> set test6380 "hello6380" OK

五、常用操作命令

5.1 停止实例

# 停止6379实例 redis-cli -p 6379 -a redis6379 shutdown # 停止6380实例 redis-cli -p 6380 -a redis6380 shutdown

5.2 重启实例

先停止实例,再重新执行启动命令:

# 重启6379实例 redis-server /root/lamp/redis_instance/6379/conf/redis_6379.conf

六、总结

单台 CentOS 服务器部署多个 Redis 实例的核心是「配置隔离」,无需重复编译安装 Redis,只需为每个实例分配独立端口、配置文件和数据目录即可。本文从编译安装到多实例部署全程实操,解决了常见的 jemalloc 编译报错,适合 Redis 入门学习者参考。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 13:35:37

图像生成的新拐点:谷歌Nano Banana Pro的四大革命性突破与战略价值

谷歌的最新图像生成模型 Nano Banana Pro (NBP) 的发布,标志着 AI 图像生成技术正式跨越了从“创造艺术”到“创造实用价值”的门槛。它不仅仅是一个出图工具,更是谷歌在 AI 时代对效率、专业控制和生态整合发起的一次战略性挑战。 我们将从四个核心维度…

作者头像 李华
网站建设 2026/4/16 13:13:38

Docker容器化实践:从开发到生产的完整流程

前言 "在我电脑上能跑啊!"这句话曾经是我们团队的口头禅。环境不一致导致的问题层出不穷,直到我们引入了Docker。 这篇文章分享我们的Docker实践经验。 一、为什么选择Docker? 1.1 传统部署的痛点 bash # 开发环境 Python 3.8 …

作者头像 李华
网站建设 2026/4/17 3:44:07

2025年Go加密安全爆料:你的系统真的安全吗?量子威胁早就来了!

开头:震撼现实 想象一下,有人现在就在录制你的加密通信,用来等待未来的量子计算机。这不是科幻小说,这是真实发生的 “现在记录,未来解密” 攻击——密码学中最恐怖的威胁。 2025年对Go开发者来说是个转折点:NIST终于敲定了后量子密码标准。Go 1.24刚刚把ML-KEM(量子抗…

作者头像 李华
网站建设 2026/4/16 11:32:28

A7.4.8 Response signaling

1. 原子操作完成的可见性定义 规则: 写响应(B通道)表明原子操作的结果已对所有必需观察者可见。 对于包含读响应的原子操作(AtomicLoad/Swap/Compare),从接收到第一个读数据项时起,操作结果就可见。 管理器可使用读响应或写响应中的任意一个作为操作完成的指示。 举例…

作者头像 李华
网站建设 2026/4/16 11:47:53

软件测试常见面试题及答案

软件测试常见面试题及答案 乐搏软件学院 2017-09-22 10:14:37 软件测试常见面试题及答案 软件测试常见面试题及答案 软件测试方法有哪些分类?各有什么特点?设计测试用例的主要方法有哪些? 软件测试方法分类 1)白盒、黑盒、灰盒…

作者头像 李华