Docker安装redis
⭐一、服务器配置🍒关闭防火墙、沙盒、iptables🍒安装docker⭐二、Docker搜索redis镜像⭐三、Docker拉取镜像⭐四、Docker挂载配置文件⭐五、启动redis 容器🍒启动命令🍒参数解析🍒老版本启动报错⭐六、测试redis🍒查看启动状态🍒查看容器日志🍒查看redis命令是否正常⭐七、配置文件⭐使用[RedisDesktopManager]工具进行连接⭐一、服务器配置
🍒关闭防火墙、沙盒、iptables
systemctl stop firewalld && systemctl disable firewalldsetenforce 0vim /etc/selinux/config #编辑 SELINUX=disablediptables -F && iptables-save
🍒安装docker
yum -y install dockersystemctl start dockersystemctl enable docker# docker版本[root@localhost ~]# docker --versionDocker 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/confcd /data/redis/confvi 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 noport 6379tcp-backlog 511#redis密码 强烈建议设置复杂一些requirepass qwe123timeout 0tcp-keepalive 300daemonize nosupervised nopidfile /var/run/redis_6379.pidloglevel noticelogfile ""databases 30always-show-logo yessave 900 1save 300 10save 60 10000stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename dump.rdbdir ./replica-serve-stale-data yesreplica-read-only yesrepl-diskless-sync norepl-disable-tcp-nodelay noreplica-priority 100lazyfree-lazy-eviction nolazyfree-lazy-expire nolazyfree-lazy-server-del noreplica-lazy-flush noappendonly yesappendfilename "appendonly.aof"no-appendfsync-on-rewrite noauto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 64mbaof-load-truncated yesaof-use-rdb-preamble yeslua-time-limit 5000slowlog-max-len 128notify-keyspace-events ""hash-max-ziplist-entries 512hash-max-ziplist-value 64list-max-ziplist-size -2list-compress-depth 0set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64hll-sparse-max-bytes 3000stream-node-max-bytes 4096stream-node-max-entries 100activerehashing yeshz 10dynamic-hz yesaof-rewrite-incremental-fsync yesrdb-save-incremental-fsync yes