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

相关推荐
jmxwzy7 分钟前
Redis
数据库·redis·缓存
北辰当尹8 分钟前
【实习之旅】Kali虚拟机桥接模式ping通百度
java·服务器·桥接模式
零叹10 分钟前
Redis热Key——大厂是怎么解决的
数据库·redis·缓存·热key
王五周八11 分钟前
基于 Redis+Redisson 实现分布式高可用编码生成器
数据库·redis·分布式
win x13 分钟前
Redis事务
数据库·redis·缓存
Just Dreamchaser14 分钟前
Pdf和Docx文件导出生成水印工具类
java·给pdf和docx文件添加水印
这个需求做不了16 分钟前
Java实现文件格式转换(图片,视频,文档,音频)
java
超龄超能程序猿19 分钟前
Docker常用中间件部署笔记:MongoDB、Redis、MySQL、Tomcat快速搭建
笔记·docker·中间件
愿你天黑有灯下雨有伞20 分钟前
高性能Java并发编程:如何优雅地使用CompletableFuture进行异步编排
java
indexsunny21 分钟前
互联网大厂Java面试实战:基于电商场景的Spring Boot与微服务技术问答
java·spring boot·微服务·面试·hibernate·电商场景·技术问答