MENU

Docker 运行 Redis 7.0 容器实例

June 1, 2023 • Read: 1282 • 随心笔记

最近在逃离宝塔的舒适圈,虽然UI环境操作的确非常方便,开箱即用,但是宝塔官方的隐私策略、超级权限、对系统的侵入性很大等等问题,决定逃离,重新折腾这些日常环境。

环境准备:

  • debian11 宿主机操作系统
  • 必要的Docker环境
  • /home/redis,作为配置文件和数据存放目录

具体操作

安装 Docker

curl -fsSL https://get.docker.com | bash -s docker

创建目录

mkdir /home/redis

建立Redis配置文件

路径:/home/redis/redis.conf,因为决定使用的镜像是redis:7.0.11-alpine3.18,所以对应的配置文件也采用官方的版本(https://github.com/redis/redis/blob/7.0/redis.conf),否则不同版本的配置可能导致无法启动容器实例。
在官方的基础做了一些日常调整:

  • 监听地址改为:0.0.0.0,方便外界连接
  • 设置密码授权,密码为 4f2016c6b934d55bd7120e5d0e62cce3
  • 开启RDB快照备份
  • AOF策略调整为everysec,即 每秒
  • dir 设置为 /data,会与宿主机映射

具体内容:

requirepass 4f2016c6b934d55bd7120e5d0e62cce3
bind 0.0.0.0
port 6379
protected-mode yes
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
databases 16
always-show-logo no
set-proc-title yes
proc-title-template "{title} {listen-addr} {server-mode}"
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
rdb-del-sync-files no
dir /data
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync yes
repl-diskless-sync-delay 5
repl-diskless-sync-max-replicas 0
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
acllog-max-len 128
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
lazyfree-lazy-user-flush no
oom-score-adj no
oom-score-adj-values 0 200 800
disable-thp yes
appendonly yes
appendfilename "appendonly.aof"
appenddirname "appendonlydir"
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
aof-timestamp-enabled no

save 900 1
save 300 10
save 60 10000

slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-listpack-entries 512
hash-max-listpack-value 64
list-max-listpack-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-listpack-entries 128
zset-max-listpack-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
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
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
jemalloc-bg-thread yes

启动实例

参数说明

  • --restart=always 让容器始终运行
  • -p 6699:6379/tcp 宿主机6699端口映射至 Redis 6379端口
  • -v /home/redis:/data,将宿主机目录映射至容器内部,防止误删容器导致数据丢失
  • redis:7.0.11-alpine 指定镜像版本
  • redis-server /data/redis.conf 指定配置启动

最终启动命令:

docker run -d --restart=always  -p 6699:6379/tcp -v /home/redis:/data redis:7.0.11-alpine redis-server /data/redis.conf

最后docker ps -a,查看容器状态,查看Redis是否正确启动,/home/redis/是否有对应数据产生。