通过docker配置密码、持久化的redis

单纯Docker创建持久化Redis

前言

之前服务器买了之后,使用docker跑了一个Redis实例之后就放在那边不管了,直到前段时间发现Redis会莫名的删除所有的key值,可能是被黑掉了- - 于是有了这篇文章,希望通过docker来简单的配置一个有密码保护的,可持久化的Redis。

步骤

首先,我们在/usr/local/下创建一个redis文件夹,用于存放redis的配置文件和数据

mkdir /usr/local/redis
mkdir /usr/local/redis/data
touch /usr/local/redis/redis.conf
复制代码
  1. 编写配置文件
## default: 不以守护进程的方式运行 
daemonize no

## 开启aop持久化
appendonly yes
#default: 持久化文件
appendfilename "appendonly.aof"
#default: 每秒同步一次
appendfsync everysec

port 6379
# 绑定端口,不指定外网可能连不上服务器
bind 0.0.0.0
requirepass password
复制代码
  1. 编写一个docker的指令

vim redis.sh

docker run 
-p 6379:6379 
--name redis 
-v /usr/local/redis/redis.conf:/etc/redis/redis.conf ##将redis.conf挂在到docker的etc/redis目录下
-v /usr/local/redis/data:/data 
-d redis:6.0
redis-server /etc/redis/redis.conf ##追加指令 运行redis服务器并指定刚刚挂载的配置文件
复制代码
  1. 使用sh redis.sh启动redis 并使用docker ps查看运行状态

docker中redis没有跑起来则通过docker logs redis查看报错信息

线上配置密码

对于已经开启的Redis如果不想通过配置文件设置密码的话,可以通过指令

config set requirepass [password]来线上配置命令

另外,值得一提的是通过指令进行配置的密码不会同步到redis.conf配置文件中喔

Guess you like

Origin juejin.im/post/7032312820024737799