Docker安装redis(保姆级教程&图文并茂)

发布于:2022-12-18 ⋅ 阅读:(590) ⋅ 点赞:(0)

在这里插入图片描述

⭐一、服务器配置


🍒关闭防火墙、沙盒、iptables

systemctl stop firewalld  && systemctl disable firewalld
setenforce 0
vim /etc/selinux/config 
#编辑  SELINUX=disabled
iptables -F &&  iptables-save

🍒安装docker

yum -y install docker
systemctl start docker
systemctl enable docker

# docker版本
[root@localhost ~]# docker --version
Docker version 1.13.1, build 7d71120/1.13.1

⭐二、Docker搜索redis镜像


docker search redis

在这里插入图片描述

⭐三、Docker拉取镜像


docker pull redis

在这里插入图片描述

⭐四、Docker挂载配置文件


  • 挂载redis的配置文件
  • 挂载redis 的持久化文件(为了数据的持久化)

宿主机的位置选择可以根据磁盘空间大小自由选择

宿主机redis.cof文件位置 : /data/redis/conf/redis.cof

mkdir -p /data/redis/conf
cd /data/redis/conf
vi redis.conf
#将⭐七、配置文件内容 进行复制

宿主机redis-data位置 : /data/redis/data

mkdir -p /data/redis/data

⭐五、启动redis 容器


🍒启动命令

docker run -itd --name redis --restart=always --log-opt max-size=100m --log-opt max-file=2 -p 6379:6379 -v /data/redis/conf/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data  redis redis-server /etc/redis/redis.conf --appendonly yes  --requirepass qwe123

🍒参数解析

  • 【 --restart=always】 开机启动,失败也会一直重启;
  • 【–log-opt max-size=100m】意味着一个容器日志大小上限是100M;
  • 【–log-opt max-file=2】意味着一个容器有2个日志,分别是id+.json、id+1.json;
  • 【-p 6379:6379】 将宿主机6379端口与容器内6379端口进行映射;
  • 【-v】 将宿主机目录或文件与容器内目录或文件进行挂载映射;
  • 【-itd】
    i:以交互模式运行容器,通常与 -t 同时使用;
    t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;
    d:表示后台启动redis;
  • 【–name】 给容器命名;
  • 【–appendonly yes】 开启redis 持久化;
  • 【–requirepass qwe123】 强烈建议设置密码,并且将密码设置为高强度复杂;
  • 【redis-server /etc/redis/redis.conf】 以配置文件启动redis,加载容器内的conf文件;

🍒老版本启动报错

老版本docker在启动的时候可能会报错;是因为老版本的docker日志驱动程序是:journald

... unknown log opt 'max-file' for journald log driver

修改配置文件

vim /etc/sysconfig/docker
#编辑
原文:OPTIONS='--selinux-enabled --log-driver=journald --signature-verification=false'
编辑后:OPTIONS='--selinux-enabled --log-driver=json-file --signature-verification=false'

重启dokcer加载配置文件

systemctl daemon-reload && systemctl restart docker

⭐六、测试redis


🍒查看启动状态

docker ps -a | grep redis

在这里插入图片描述

🍒查看容器日志

docker logs -f  redis

在这里插入图片描述

🍒查看redis命令是否正常

docker exec -it redis redis-cli

在这里插入图片描述

⭐七、配置文件


redis.conf配置文件

protected-mode no

port 6379

tcp-backlog 511
#redis密码 强烈建议设置复杂一些
requirepass qwe123     

timeout 0

tcp-keepalive 300

daemonize no

supervised no

pidfile /var/run/redis_6379.pid

loglevel notice

logfile ""

databases 30

always-show-logo yes

save 900 1
save 300 10
save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir ./

replica-serve-stale-data yes

replica-read-only yes

repl-diskless-sync no

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

appendonly yes

appendfilename "appendonly.aof"

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

lua-time-limit 5000

slowlog-max-len 128

notify-keyspace-events ""

hash-max-ziplist-entries 512
hash-max-ziplist-value 64

list-max-ziplist-size -2

list-compress-depth 0

set-max-intset-entries 512

zset-max-ziplist-entries 128
zset-max-ziplist-value 64

hll-sparse-max-bytes 3000

stream-node-max-bytes 4096
stream-node-max-entries 100

activerehashing yes

hz 10

dynamic-hz yes

aof-rewrite-incremental-fsync yes

rdb-save-incremental-fsync yes

⭐使用[RedisDesktopManager]工具进行连接

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述