news 2026/6/13 22:58:03

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/6/14 4:21:18

基于C# WinForm实现的仿微信打飞机游戏

一、游戏架构设计 1. 分层架构模型 // 游戏主框架 public class GameForm : Form {private GameEngine engine;private SpriteManager spriteManager;protected override void OnLoad(EventArgs e) {engine new GameEngine(this);spriteManager new SpriteManager();Initiali…

作者头像 李华
网站建设 2026/6/10 13:34:50

TensorFlow 深度解析:从基础到实战的全维度指南

引言:人工智能时代的核心驱动力 在人工智能与机器学习飞速发展的今天,深度学习框架已成为技术落地的核心基础设施。TensorFlow 作为谷歌开源的深度学习框架,自 2015 年首次发布以来,凭借其强大的功能、灵活的架构和庞大的社区支持…

作者头像 李华
网站建设 2026/6/12 22:16:19

手搓RPC框架系列(一):基于架构设计原则的RPC基础架构设计

文 / Kenyon,资深软件架构师,15年软件开发和技术管理经验,从程序员做到企业技术高管,专注技术管理、架构设计、AI技术应用和落地。由于公众号推流的原因,请在关注页右上角加星标,这样才能及时收到新文章的推…

作者头像 李华
网站建设 2026/6/13 1:55:53

首发,速创API上线wan2.6模型API接口,中国版sora来啦

首发,速创API上线wan2.6模型API接口,中国版sora来啦 2025年12月16日,重磅官宣:**速创API同步全球首发接入「Wan 2.6」视频模型(中国版SORA2)** ! 无论是个人创作者的一键生成,还是企…

作者头像 李华
网站建设 2026/6/11 22:15:46

Nano Banana Pro 的“降维打击”:AI 芯片和硬件格局的战略重塑

在过去的 AI 浪潮中,硬件一直是瓶颈,尤其是高性能计算的 GPU,成为了事实上的“AI 军火商”。然而,谷歌的 Nano Banana Pro (NBP) 带来的最大战略威胁,在于它证明了极致优化的软件和算法,可以挑战传统硬件的…

作者头像 李华