使用 Docker Compose 安装 Redis 7.2.4
前面是指南,后面是主要步骤实际执行日志
使用 Docker Compose 安装 Redis 7.2.4
以下是使用 Docker Compose 安装 Redis 7.2.4 的完整指南:
1. 创建项目目录和文件
bash
复制
下载
# 创建项目目录 mkdir redis-docker && cd redis-docker# 创建必要目录 mkdir -p data conf
2. 创建 docker-compose.yml 文件
yaml
复制
下载
# docker-compose.yml version: '3.8'services:redis:image: redis:7.2.4container_name: redis-serverrestart: unless-stoppedports:- "6379:6379"volumes:- ./data:/data- ./conf/redis.conf:/usr/local/etc/redis/redis.confcommand: redis-server /usr/local/etc/redis/redis.confenvironment:- TZ=Asia/Shanghainetworks:- redis-netnetworks:redis-net:driver: bridge
3. 创建 Redis 配置文件
bash
复制
下载
# 创建配置文件 cat <<EOF > conf/redis.conf # Redis 7.2.4 基础配置bind 0.0.0.0 port 6379 protected-mode yes daemonize no supervised no pidfile /var/run/redis_6379.pid loglevel notice logfile "" databases 16 always-show-logo no# 持久化配置 save 900 1 save 300 10 save 60 10000 stop-writes-on-bgsave-error yes rdbcompression yes rdbchecksum yes dbfilename dump.rdb dir /data appendonly yes appendfilename "appendonly.aof" appendfsync everysec no-appendfsync-on-rewrite no auto-aof-rewrite-percentage 100 auto-aof-rewrite-min-size 64mb aof-load-truncated yes aof-use-rdb-preamble yes# 内存管理 maxmemory 1gb maxmemory-policy allkeys-lru maxmemory-samples 5# 安全设置 # requirepass yourstrongpassword# 高级设置 timeout 0 tcp-keepalive 300 repl-backlog-size 1mb repl-backlog-ttl 3600 replica-serve-stale-data yes replica-read-only yes repl-diskless-sync no repl-diskless-sync-delay 5 repl-disable-tcp-nodelay no replica-priority 100 lazyfree-lazy-eviction no lazyfree-lazy-expire no lazyfree-lazy-server-del no replica-lazy-flush no# 性能优化 hz 10 dynamic-hz yes aof-rewrite-incremental-fsync yes rdb-save-incremental-fsync yes activerehashing yes client-output-buffer-limit normal 0 0 0 client-output-buffer-limit replica 256mb 64mb 60 client-output-buffer-limit pubsub 32mb 8mb 60# 集群模式 (单节点不需要) # cluster-enabled no # cluster-config-file nodes.conf # cluster-node-timeout 15000 # cluster-replica-validity-factor 10 # cluster-migration-barrier 1 # cluster-require-full-coverage yes EOF
4. 启动 Redis 服务
bash
复制
下载
# 启动服务 docker-compose up -d# 查看服务状态 docker-compose ps# 预期输出: # Name Command State Ports # ---------------------------------------------------------------------------- # redis-server docker-entrypoint.sh redis ... Up 0.0.0.0:6379->6379/tcp
5. 验证安装
bash
复制
下载
# 测试 Redis 连接 docker-compose exec redis redis-cli ping # 应返回: PONG# 查看 Redis 信息 docker-compose exec redis redis-cli info server# 检查持久化 docker-compose exec redis redis-cli save ls -lh data/
6. 基本操作和管理
进入 Redis CLI
bash
复制
下载
docker-compose exec redis redis-cli
常用命令
bash
复制
下载
# 设置键值 SET mykey "Hello Redis"# 获取键值 GET mykey# 查看所有键 KEYS *# 查看内存使用 INFO memory# 查看客户端连接 CLIENT LIST
管理服务
bash
复制
下载
# 停止服务 docker-compose down# 启动服务 docker-compose up -d# 重启服务 docker-compose restart# 查看日志 docker-compose logs -f
7. 自定义配置
要修改 Redis 配置:
-
编辑
conf/redis.conf
文件 -
重启服务:
docker-compose restart
常用配置选项:
-
设置密码:取消注释并修改
requirepass yourstrongpassword
-
调整内存限制:修改
maxmemory
值 -
更改持久化策略:设置
appendonly no
禁用 AOF -
启用集群模式:取消注释集群相关配置
8. 数据持久化说明
-
数据保存在
./data
目录中:-
dump.rdb
:RDB 快照文件 -
appendonly.aof
:AOF 日志文件
-
-
即使容器重启或删除,数据也会保留
-
定期备份
data
目录以确保数据安全
9. 升级 Redis 版本
要升级 Redis 版本:
-
修改
docker-compose.yml
中的镜像标签:yaml
复制
下载
image: redis:7.2.5 # 新版本
-
执行升级:
bash
复制
下载
docker-compose down docker-compose pull docker-compose up -d
10. 安全建议
-
设置强密码:
-
在
redis.conf
中设置requirepass
-
连接时使用:
redis-cli -a yourpassword
-
-
限制访问:
bash
复制
下载
# 在服务器防火墙限制访问 sudo ufw allow from 192.168.1.0/24 to any port 6379
-
启用 TLS(高级):
conf
复制
下载
# 在 redis.conf 中添加 tls-port 6379 tls-cert-file /path/to/redis.crt tls-key-file /path/to/redis.key
这个安装方案提供了 Redis 7.2.4 的稳定运行环境,包含了合理的默认配置和持久化设置,适合生产环境使用。
[root@centos08 work]# cd /software/wenxue/
[root@centos08 wenxue]# ls
docker-compose-linux-x86_64 milvsu.tar milvus-docker-compose.yml
[root@centos08 wenxue]# mkdir redis-docker && cd redis-docker
[root@centos08 redis-docker]# mkdir -p data conf
[root@centos08 redis-docker]# ls
conf data
[root@centos08 redis-docker]# pwd
/software/wenxue/redis-docker
[root@centos08 redis-docker]# vi docker-compose.yml
[root@centos08 redis-docker]# ls
conf data docker-compose.yml
[root@centos08 redis-docker]# cat <<EOF > conf/redis.conf
> # Redis 7.2.4 基础配置
>
> bind 0.0.0.0
> port 6379
> protected-mode yes
> daemonize no
> supervised no
> pidfile /var/run/redis_6379.pid
> loglevel notice
> logfile ""
> databases 16
> always-show-logo no
>
> # 持久化配置
> save 900 1
> save 300 10
> save 60 10000
> stop-writes-on-bgsave-error yes
> rdbcompression yes
> rdbchecksum yes
> dbfilename dump.rdb
> dir /data
> appendonly yes
> appendfilename "appendonly.aof"
> appendfsync everysec
> no-appendfsync-on-rewrite no
> auto-aof-rewrite-percentage 100
> auto-aof-rewrite-min-size 64mb
> aof-load-truncated yes
> aof-use-rdb-preamble yes
>
> # 内存管理
> maxmemory 1gb
> maxmemory-policy allkeys-lru
> maxmemory-samples 5
>
> # 安全设置
> # requirepass yourstrongpassword
>
> # 高级设置
> timeout 0
> tcp-keepalive 300
> repl-backlog-size 1mb
> repl-backlog-ttl 3600
> replica-serve-stale-data yes
> replica-read-only yes
> repl-diskless-sync no
> repl-diskless-sync-delay 5
> repl-disable-tcp-nodelay no
> replica-priority 100
> lazyfree-lazy-eviction no
> lazyfree-lazy-expire no
> lazyfree-lazy-server-del no
> replica-lazy-flush no
>
> # 性能优化
> hz 10
> dynamic-hz yes
> aof-rewrite-incremental-fsync yes
> rdb-save-incremental-fsync yes
> activerehashing yes
> client-output-buffer-limit normal 0 0 0
> client-output-buffer-limit replica 256mb 64mb 60
> client-output-buffer-limit pubsub 32mb 8mb 60
>
> # 集群模式 (单节点不需要)
> # cluster-enabled no
> # cluster-config-file nodes.conf
> # cluster-node-timeout 15000
> # cluster-replica-validity-factor 10
> # cluster-migration-barrier 1
> # cluster-require-full-coverage yes
> EOF
[root@centos08 redis-docker]# ls
conf data docker-compose.yml
[root@centos08 redis-docker]# ls ./conf/
redis.conf
[root@centos08 redis-docker]# docker-compose up -d
WARN[0000] /software/wenxue/redis-docker/docker-compose.yml: the attribute `version` is obsolete, it will be ignored, please remove it to avoid potential confusion
[+] Running 9/9
✔ redis Pulled 61.2s
✔ 09f376ebb190 Pull complete 20.2s
✔ f89f5b53601e Pull complete 20.5s
✔ 45d9097e8d82 Pull complete 21.0s
✔ b14e0d774d3d Pull complete 21.5s
✔ e8f49d7b64bc Pull complete 22.8s
✔ 17bfefd8913f Pull complete 58.6s
✔ 4f4fb700ef54 Pull complete 58.8s
✔ d05f3a965cb3 Pull complete 59.1s
[+] Running 2/2
✔ Network redis-docker_redis-net Created 0.2s
✔ Container redis-server Started 1.7s
[root@centos08 redis-docker]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9b33aebb8399 redis:7.2.4 "docker-entrypoint.s…" 57 seconds ago Up 54 seconds 0.0.0.0:6379->6379/tcp redis-server
321d1c59a8fa zilliz/attu:v2.3.3 "docker-entrypoint.s…" 2 hours ago Up 2 hours 0.0.0.0:8000->3000/tcp milvus-attu
f0a8261e9f83 quay.io/coreos/etcd:v3.5.5 "etcd -advertise-cli…" 2 hours ago Up 2 hours 2379-2380/tcp milvus-etcd
8cb9513cf532 minio/minio:RELEASE.2023-03-20T20-16-18Z "/usr/bin/docker-ent…" 2 hours ago Up 2 hours (healthy) 0.0.0.0:9000-9001->9000-9001/tcp, 0.0.0.0:9090->9090/tcp milvus-minio
[root@centos08 redis-docker]# docker ps | grep redis
9b33aebb8399 redis:7.2.4 "docker-entrypoint.s…" About a minute ago Up About a minute 0.0.0.0:6379->6379/tcp redis-server
[root@centos08 redis-docker]#
相关文章:
使用 Docker Compose 安装 Redis 7.2.4
前面是指南,后面是主要步骤实际执行日志 使用 Docker Compose 安装 Redis 7.2.4 以下是使用 Docker Compose 安装 Redis 7.2.4 的完整指南: 1. 创建项目目录和文件 bash 复制 下载 # 创建项目目录 mkdir redis-docker && cd redis-docker#…...

35.x64汇编写法(二)
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:34.x64汇编写法(一) 上一个内容写了,汇编调…...

安全大模型的思考
马上要准备2025年的护网了,最近就一直很忙,被事情裹挟着前进,忙的晕头转向,近乎感冒,昨天部门搞了一场AI大模型培训,演讲者有着很深的技术底蕴,我听到了一句关于Sass数据验证这块大为感悟&#…...
SQL Server 2025 预览版新功能
T-SQL 语言增强 正则表达式 (Regex) 支持 功能概述: SQL Server 2025 在 T-SQL 中原生引入了 POSIX 兼容的正则表达式支持,通过内置函数(如 REGEXP_LIKE、REGEXP_REPLACE 等)可直接在查询中对文本进行复杂模式匹配、查找和替换。…...

NineData云原生智能数据管理平台新功能发布|2025年5月版
本月发布 6 项更新,其中重点发布 3 项、功能优化 3 项。 重点发布 数据库 DevOps - 多源敏感数据保护 敏感数据扫描能力大幅扩展,新增支持 TiDB、Doris、SelectDB、OceanBase MySQL、GreatSQL、StarRocks、ClickHouse、SingleStore、Lindorm 9 种大数据…...
数学复习笔记 25
今天能把第五章学完。加油。今年是最好上岸的一年。 5.23:全是单根,笑死,居然难受了。我现在每个题,都要总结。总结。总结实际上也总结不出啥东西。但是我一定要总结。主动让自己思考一下。老师的思路很清奇。他认为考的稀松平常…...

Linux可执行文件ELF文件结构
目标文件格式 编译器编译源代码后生成的文件叫做目标文件,而目标文件经过编译器链接之后得到的就是可执行文件。那么目标文件到底是什么?它和可执行文件又有什么区别?链接到底又做了什么呢?接下来,我们将探索一下目标…...
RAG:大模型微调的革命性增强——检索增强生成技术深度解析
RAG:大模型微调的革命性增强——检索增强生成技术深度解析 当大模型遇到知识瓶颈,RAG(检索增强生成)为模型装上"外部记忆库",让静态知识库与动态生成能力完美融合。本文将深入拆解RAG的技术原理、微调策略及…...

DisplayPort 2.0协议介绍(1)
最近开始学习DisplayPort 2.0协议,相比于DP1.4a,最主要的是速率提升到了10Gbps/lane,还有就是128b/132b编码方式的修改。至于速率13.5Gbps和20Gbps还只是可选项,在DP2.1协议才成为必须支持选项。 那在实现技术细节上有哪些变化呢…...

I2C通信讲解
I2C总线发展史 怎么在一条串口线上连接多个设备呢? 由于速度同步线是由主机实时发出的,所以主机可以按需求修改通信速度,这样在一条线上可以挂接不同速度的器件,单片机和性能差的器件通信,就输出较慢的脉冲信号&#x…...
【信息系统项目管理师-选择真题】2025上半年(第一批)综合知识答案和详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 【第1题】【第2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20题】【第…...
ABP VNext 在 Kubernetes 中的零停机蓝绿发布
ABP VNext 在 Kubernetes 中的零停机蓝绿发布 🚀 📚 目录 ABP VNext 在 Kubernetes 中的零停机蓝绿发布 🚀📌 一、前提准备 ℹ️🧱 二、项目结构与目标 🎯🐳 三、多阶段 Dockerfile 构建 &#…...
linux 故障处置通用流程-36计-14-27
014:查看系统主要日志 查看以下日志: 主要查以下关键字 error/NIC/fs /"link down"/Oout of memory" /var/log/messages /var/log/dmesg 015:主机通讯是否延迟 执行命令: #ping 网关_IP #ping 关联主机_IP …...
https和http有什么区别-http各个版本有什么区别
http和 https的区别 HTTP(超文本传输协议)和 HTTPS(安全超文本传输协议)是两种用于在网络上传输数据的协议,它们的主要区别在于安全性: HTTP(Hypertext Transfer Protocol)&#x…...

基于回归算法的心理健康预测(EDA + 预测)
心理健康涵盖情感、心理与社会福祉,影响认知、情绪和行为模式,决定压力应对、人际交往及健康决策,且在生命各阶段(从童年至成年)均至关重要。心理健康与身体健康同为整体健康的核心要素:抑郁会增加糖尿病、…...
React Native开发鸿蒙运动健康类应用的项目实践记录
项目名称:HarmonyFitness - 基于React Native的鸿蒙运动健康应用 技术栈:React Native 0.72.5 TypeScript HarmonyOS API ArkTS原生模块 一、环境搭建与项目初始化 双环境配置 React Native环境: npx re…...

【新品解读】一板多能,AXRF49 定义新一代 RFSoC FPGA 开发平台
“硬件系统庞杂、调试周期长” “高频模拟前端不稳定,影响采样精度” “接收和发射链路难以同步,难以扩展更多通道” “数据流量大,处理与存储跟不上” 这些是大部分客户在构建多通道、高频宽的射频采样链路时,面临的主要问题。…...

贪心算法应用:线性规划贪心舍入问题详解
贪心算法应用:线性规划贪心舍入问题详解 贪心算法是一种在每一步选择中都采取当前状态下最优的选择,从而希望导致结果是全局最优的算法策略。在线性规划问题中,贪心算法特别是贪心舍入技术有着广泛的应用。下面我将全面详细地讲解这一主题。…...

YOLO在C#中的完整训练、验证与部署方案
YOLO在C#中的完整训练、验证与部署方案 C# 在 YOLO 部署上优势明显(高性能、易集成),但训练能力较弱,通常需结合 Python 实现。若项目对开发效率要求高且不依赖 C# 生态,建议全程使用 Python;若需深度集成…...
洛谷题目:P2761 软件补丁问题 (本题简单)
个人介绍: 题目传送门: P2761 软件补丁问题 - 洛谷 (luogu.com.cn) 前言: 这道题是一个典型的状态搜索问题,核心目标就是利用给定d额多个补丁程序,将包含若干错误的软件修复成没有错误的状态,并且要使得修复过程当中的总耗时最少。下面是小亦为大家阐述滴思路: 1、状态…...

智慧园区数字孪生全链交付方案:降本增效30%,多案例实践驱动全周期交付
在智慧园区建设浪潮中,数字孪生技术正成为破解传统园区管理难题的核心引擎。通过构建与物理园区1:1映射的数字模型,实现数据集成、状态同步与智能决策,智慧园区数字孪生全链交付方案已在多个项目中验证其降本增效价值——某物流园区通过该方案…...

【OpenGL学习】(四)统一着色和插值着色
文章目录 【OpenGL学习】(四)统一着色和插值着色统一着色(Flat/Uniform Shading)插值着色(Interpolated Shading) 【OpenGL学习】(四)统一着色和插值着色 着色器介绍: h…...
42、响应处理-【源码分析】-浏览器与PostMan内容协商完全适配
42、响应处理源码分析浏览器与PostMan内容协商完全适配 要实现浏览器与PostMan在内容协商上的完全适配,需要在Spring Boot应用中自定义内容协商策略,确保服务器能根据浏览器和PostMan的请求头正确返回合适格式的数据。以下是详细的步骤: ### …...

在 CentOS 上安装 Docker 和 Docker Compose 并配置使用国内镜像源
在 CentOS 上安装 Docker 和 Docker Compose 并配置使用国内镜像源,可以加速镜像下载速度。以下是详细的步骤: 一、安装 Docker 移除旧版本的 Docker(如果有): sudo yum remove docker \docker-client \docker-client…...
Java Lambda表达式深度解析:从入门到实战
简介 Lambda表达式是Java 8引入的最重要特性之一,它极大地简化了Java代码的编写方式,使函数式编程风格在Java中成为可能。本文将全面介绍Lambda表达式的概念、语法、应用场景以及与相关特性的配合使用,帮助开发者掌握这一强大的编程工具。 一、Lambda表达式基础 1.1 什么…...

Docker慢慢学
1、Docker DeskTop 2、N8N下载 docker run -p 8888:5678 n8nio/n8n 3、Kafka kafka依赖zookeeper,先启动zookeeper docker pull zookeeper docker run -d --name zookeeper -p 2181:2181 -e ALLOW_ANONYMOUS_LOGINyes zookeeper 启动kafka docker pull confluentinc/cp…...

cursor-free-vip使用
一、项目简介 Cursor-Free-VIP 是一个开源项目,旨在帮助用户免费使用 Cursor AI 的高级功能。它通过自动注册 Cursor 账号、重置机器 ID 和完成 Auth 验证等操作,解决 Cursor AI 中常见的限制提示。 二、系统准备 1…cursor需要更新到最新的版本 三、…...

使用SSH tunnel访问内网的MySQL
文章目录 环境背景方法参考 注:本文是使用SSH tunnel做端口转发的一个示例。有关SSH端口转发,可参考我的几篇文档 https://blog.csdn.net/duke_ding2/article/details/106878081https://blog.csdn.net/duke_ding2/article/details/135627263https://blo…...

Redis持久化模式RDB与AOF
RDB持久化 RDB也被叫做Redis数据快照。简单来说就是把内存中的所有数据记录到磁盘中。当Redis实例故障重启后重磁盘中读取快照文件进行数据恢复(快照文件默认保存在当前运行目录); 演示Redis正常停机自动执行一次RDB操作 配置Redis触发RDB机制 RDB其它配置也可在red…...
【JS进阶】ES5 实现继承的几种方式
ES5 实现继承的几种方式 1. 原型链继承(Prototype Chaining) function Parent(name) {this.name name || Parent;this.colors [red, blue]; }Parent.prototype.sayName function() {console.log(this.name); };function Child() {}// 关键ÿ…...