Redis部署-总结版

一、部署步骤总结

1. 环境准备

  • 服务器:阿里云 CentOS 系统

  • 安装 Docker 及 Docker Compose V2 插件

  • 优化宿主机内核参数:

    bash

    复制代码
    echo "vm.overcommit_memory = 1" >> /etc/sysctl.conf && sysctl -p
    echo never > /sys/kernel/mm/transparent_hugepage/enabled
    # CentOS 永久关闭透明大页(通过 systemd 服务)

2. 项目目录结构

text

复制代码
/opt/campus_project/campus_crowdfunding/
├── docker-compose.yml
├── .env
├── redis.conf
├── prometheus.yml
├── secrets/
│   └── redis_password.txt
├── backup-redis.sh
└── ... (应用代码)

3. Redis 配置优化(redis.conf

  • 绑定所有接口,密码从 Docker secret 文件读取

  • 开启混合持久化:appendonly yes + aof-use-rdb-preamble yes

  • 设置 RDB 快照策略

  • 内存限制与 LRU 淘汰策略:maxmemory 512mb + maxmemory-policy allkeys-lru

  • 慢查询日志、TCP 连接优化

4. Docker Compose 整合

  • 添加 Redis 服务,挂载 redis.conf 和 secret 文件

  • 配置健康检查(后续调整)

  • 应用服务 campus_app 通过 depends_on 依赖 MySQL 和 Redis 健康状态

  • 环境变量传递:REDIS_URL=redis://redis:6379/0REDIS_PASSWORD_FILE

5. 密码安全管理

  • 创建 secrets/redis_password.txt,权限 600

  • .env 中设置 REDIS_PASSWORD 保持一致

  • 应用容器挂载 secret 文件,通过 REDIS_PASSWORD_FILE 读取

6. 备份脚本与定时任务

  • 编写 backup-redis.sh:触发 BGSAVE,打包 redis_data 目录,保留 7 天

  • 配置 crontab 每天凌晨 3 点执行

7. 启动与验证

  • docker compose up -d 启动所有服务

  • 检查容器状态、Redis 连接测试、应用日志


二、遇到的问题及解决方案

问题 原因 解决方案
1. Redis 容器健康检查失败 健康检查命令中使用 CMD-SHELL 且密码包含特殊字符 !@#,shell 解析错误导致认证失败 改用 CMD 格式的健康检查: test: ["CMD", "redis-cli", "-a", "$$(cat $${REDIS_PASSWORD_FILE})", "ping"]
2. docker-compose.ymlversion is obsolete 警告 Docker Compose V2 不再需要 version 字段 删除文件第一行的 version: '3.8'
3. 应用连接 Redis 报 AUTH failed: WRONGPASS 密码文件末尾含有换行符 \n,应用读取文件时密码变为 "MyPass\n" 使用 printf '%s' '密码' > secrets/redis_password.txt 重新生成无换行符的密码文件
4. 宿主机透明大页永久关闭失败(CentOS 无 apt 命令) 最初给出的 Ubuntu 命令不适用 CentOS 改用 CentOS 的 systemd 服务方式永久关闭: 创建 /etc/systemd/system/disable-thp.service 并启用
5. 使用 echo 带双引号写入密码时触发 bash 历史展开 密码中包含 !,bash 将其解释为历史命令扩展 改用单引号或 printfecho -n '密码' > fileprintf '%s' '密码' > file
6. 容器内缺少 redis-cli 或 Python redis 模块 应用镜像未预装 Redis 客户端工具 临时安装 redis-tools 测试,或使用 Python 一行命令测试连接,测试后不影响生产
7. 担心阿里云安全组需开放 Redis 端口 误解为需要外部访问 明确解释:应用与 Redis 在同一 Docker 网络内部通信,ports: "127.0.0.1:6379:6379" 仅绑定本地,安全组无需开放任何 Redis 端口

三、最终部署架构

text

复制代码
┌─────────────────────────────────────────────────────────┐
│                    阿里云 CentOS 服务器                    │
│  ┌───────────────────────────────────────────────────┐  │
│  │              Docker Compose 项目                    │  │
│  │  ┌──────────┐  ┌──────────┐  ┌───────────────┐  │  │
│  │  │  MySQL   │  │  Redis   │  │  campus_app   │  │  │
│  │  │  :3306   │  │  :6379   │◀─┤   :8000       │  │  │
│  │  └──────────┘  └──────────┘  └───────────────┘  │  │
│  │        ▲             ▲              ▲             │  │
│  │        └─────────────┴──────────────┘             │  │
│  │              内部网络(服务名通信)                    │  │
│  └───────────────────────────────────────────────────┘  │
│                    ▲                                    │
│                    │ 宿主机端口映射                       │
│                    ▼                                    │
│         127.0.0.1:6379 (仅本地)                         │
│         0.0.0.0:8000   (对外提供 Web 服务)               │
└─────────────────────────────────────────────────────────┘

四、后续运维注意事项

  • 监控:通过 Grafana (端口 3000) 查看系统及 Redis 指标

  • 备份 :每日自动备份 Redis 数据到 /opt/backups/redis

  • 安全红线:切勿在阿里云安全组放行 6379 端口,Redis 仅限内部访问

  • 更新应用docker compose up -d --build campus_app


相关推荐
小马爱打代码3 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人5 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat5 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中5 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪5 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客6 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP7 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_7 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬8 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存