Redis容器化(Docker)

Redis容器化(Docker)

生产级部署(带持久化 + 自定义配置)

生产环境中需要保证数据持久化、自定义配置(如密码、内存限制),推荐这种方式。

1,拉取 Redis 8 官方镜像

bash 复制代码
docker pull redis:8

2,创建本地目录(用于挂载配置和数据)

bash 复制代码
# 创建配置目录和数据目录
mkdir -p /opt/redis8/{conf,data}
chmod 777 /opt/redis8/data  # 赋予写入权限,避免权限问题

3,修改redis.conf 配置文件

复制一份redis.conf到/opt/redis8/conf目录下,然后修改以下配置:

c 复制代码
# 基础配置
bind 0.0.0.0          # 允许所有IP访问(容器内必须配置,否则外部无法连接)
protected-mode no     # 关闭保护模式(配合bind 0.0.0.0使用)
port 6379             # 端口
daemonize no          # 禁止后台运行(Docker容器内必须为no,否则容器会退出)
requirepass 123456    # 设置密码(必填,生产环境务必修改)
timeout 0             # 超时时间

# 持久化配置(RDB+AOF组合,保证数据安全)
save 900 1            # 900秒内至少1个键修改则触发RDB快照
save 300 10           # 300秒内至少10个键修改则触发RDB快照
save 60 10000         # 60秒内至少10000个键修改则触发RDB快照
rdbcompression yes    # 压缩RDB文件
dbfilename dump.rdb   # RDB文件名
dir /data             # 数据存储目录(对应容器内的/data)

appendonly yes        # 开启AOF持久化
appendfilename "appendonly.aof"  # AOF文件名
appendfsync everysec  # 每秒同步一次AOF(兼顾性能和数据安全)
auto-aof-rewrite-percentage 100  # AOF文件增长100%时重写
auto-aof-rewrite-min-size 64mb   # AOF文件最小64MB才重写

4,启动容器(挂载配置 + 数据)

bash 复制代码
docker run -d \
  --name redis8 \
  --restart always \  # 容器异常退出时自动重启
  -p 6379:6379 \
  -v /opt/redis8/conf/redis.conf:/etc/redis/redis.conf \  # 挂载配置文件
  -v /opt/redis8/data:/data \  # 挂载数据目录(持久化)
  -m 2g \  # 限制Redis最大使用内存2GB(可选,根据服务器配置调整)
  --sysctl net.core.somaxconn=511 \  # 优化TCP连接参数
  redis:8 redis-server /etc/redis/redis.conf  # 指定配置文件启动

验证部署是否成功

bash 复制代码
# 1. 查看容器状态
docker ps | grep redis8

# 2. 进入容器连接Redis
docker exec -it redis8 redis-cli

# 3. 输入密码(配置文件中设置的123456)
127.0.0.1:6379> AUTH 123456
OK

# 4. 测试写入数据
127.0.0.1:6379> SET test "docker-redis8"
OK

# 5. 读取数据
127.0.0.1:6379> GET test
"docker-redis8"

# 6. 退出容器
127.0.0.1:6379> exit

常用运维命令

bash 复制代码
# 查看Redis日志
docker logs -f redis8

# 停止容器
docker stop redis8

# 启动容器
docker start redis8

# 重启容器
docker restart redis8

# 删除容器(需先停止)
docker rm redis8

# 进入容器bash
docker exec -it redis8 /bin/bash

总结
生产部署 :核心是挂载 配置文件 和 数据目录,开启持久化(RDB+AOF),设置密码和自动重启;
关键配置 :容器内必须设置 bind 0.0.0.0 和 daemonize no,否则会导致外部无法连接或容器退出。

通过以上方案,你可以快速完成 Redis 8 的 Docker 容器化部署,兼顾易用性和生产环境的稳定性

容器化redis和redis.conf配置下载链接:

https://pan.baidu.com/s/1ehXVaorwhtueETfc_DQDHA 提取码: vnjq

相关推荐
林夕sama几秒前
多线程基础(五)
java·开发语言·前端
Zzxy5 分钟前
HikariCP连接池
java·数据库
罗超驿9 分钟前
Java数据结构_栈_算法题
java·数据结构·
希望永不加班14 分钟前
SpringBoot 主启动类解释:@SpringBootApplication 到底做了什么
java·spring boot·后端·spring
ZZZKKKRTSAE27 分钟前
rhel9快速上手Docker
运维·docker·容器
筱顾大牛28 分钟前
Docker安装教程(加汉化!超详细!!!)
运维·docker·容器
蝎子莱莱爱打怪42 分钟前
别再裸用 Claude Code 了!32 个亲测Skills + 8 个 MCP,开发效率直接拉满!
java·后端·claude
九成宫1 小时前
安装和配置Docker教程(装在其他盘)
运维·docker·容器
野犬寒鸦1 小时前
JVM垃圾回收机制面试常问问题及详解
java·服务器·开发语言·jvm·后端·算法·面试
janthinasnail1 小时前
使用Docker安装nanobot(超轻量个人AI助手)
docker·容器