Docker安装Redis镜像
查询redis镜像
docker search redis
下载镜像
docker pull redis
创建文件目录
mkdir -p /data/redis/conf
mkdir -p /data/redis/data
创建redis.log文件
touch /data/redis/redis.log
chmod 777 /data/redis/redis.log #设置访问权限为777
获取redis配置文件redis.conf
http://www.redis.cn/download.html
修改redis.conf主要参数
bind 127.0.0.1 #注释掉这部分,使redis可以外部访问
requirepass #给redis设置密码
logfile /data/redis.log # 指定日志文件 !! 不加引号,这里之前加了引号出现找不文件错误
protected-mode no #关闭保护模式
————————RDB配置文件————————
# 设置 RDB 文件名和文件路径
dbfilename dump.rdb (这个是默认的)
dir /data (我从 ./改成了 /data)
----------------------------------------------------------------------(下面的不用修改)
# RDB 默认的设置 ,可以按照如下规则,根据自己的实际请求压力进行设置调整。
# 如果900秒内有1条Key信息发生变化,则进行快照;
save 900 1
#如果300秒内有10条Key信息发生变化,则进行快照;
save 300 10
#如果60秒内有10000条Key信息发生变化,则进行快照。
save 60 10000
# 启动备份文件压缩
rdbcompression yes
#redis 5之后,64位的CRC冗余校验码会放在RDB文件的末尾,以对文件完整性进行验证,但是在保存和加载RDB文件时,会损失10%左右的性能
rdbchecksum yes
# 如果持久化出错,主进程是否停止写入
stop-writes-on-bgsave-error yes
———————AOF配置文件—————————
# 开启AOF 备份
appendonly yes
# AOF文件的保存位置和RDB文件的位置相同,都是通过dir参数设置的
dir /data
# AOF持久化的文件名,默认是appendonly.aof
appendfilename "appendonly.aof"
# 同步策略
# appendfsync always
appendfsync everysec
# appendfsync no
# aof重写期间是否同步
no-appendfsync-on-rewrite no
# 触发设置
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
# 加载aof出错如何处理
aof-load-truncated yes
# 文件重写策略
aof-rewrite-incremental-fsync yes
redis.conf上传到/data/redis/conf
启动redis镜像
docker run -itd --name redis -p 6379:6379 --restart=always
-v /data/redis/conf:/usr/local/etc/redis
-v /data/redis/data:/data redis redis-server
/usr/local/etc/redis/redis.conf
--appendonly yes
命令含义:
-i:以交互模式运行容器,通常与 -t 同时使用;
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-d:后台运行容器,并返回容器ID;
-itd 为以上三个的结合
–name:给容器一个名字
-p:暴露一个端口
–appendonly yes 开启redis 持久化
–restart=always :容器退出了自动重启
-v /data/redis/conf:/usr/local/etc/redis:配置文件挂载,同理redis的数据data挂载也是这种方式
补充
—容器的配置目录可以从https://hub.docker.com/_/redis上查看如图部分
dockerps -a |grep myredis # 通过docker ps指令查看启动状态,是否成功.
[root@localhost conf]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e7d97bae4bff redis "docker-entrypoint.s…" 33 minutes ago Up 32 minutes 0.0.0.0:6379->6379/tcp redis
[root@localhost conf]#
docker logs -f redis #查看容器运行日志
容器内部进行测试
[root@localhost conf]# docker exec -it redis redis-cli
127.0.0.1:6379> set v1 2
OK
127.0.0.1:6379>