Redis

87 阅读2分钟

Redis

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第5天,点击查看活动详情

Docker安装

# 安装
$ docker pull redis:latest# 启动
$ docker run -itd --name redis -p 6379:6379 redis# 进入
$ docker exec -it redis /bin/bash$ redis-cli

Redis操作

# 运行redis-cli
$ redis-cli$ set a_key a_value
$ get a_key
$ delete a_key

Redis配置

redis.conf

# bind 127.0.0.1            #注释掉这部分,使redis可以外部访问
requirepass  redis             #给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
​
aof-use-rdb-preamble yes

删除之前的container

docker stop redis
docker container rm redis

启动

docker run -itd --name redis -p 6379:6379 \
-v /data/docker/redis/redis.conf:/etc/redis/redis.conf \
-v /data/docker/redis/data:/data \
redis redis-server /etc/redis/redis.conf 

远程访问

需要防火墙放开端口,阿里云配置安全组

telnet ip 6379
auth redis
get key_1