Docker以配置文件的方式启动Redis容器失败
解决思路:
当我们使用简单命令 docker run -p 6379:6379 --name myredis1 -d redis --requirepass "123456" ,是可以正常启动的
但是如果我们通过配置文件的方式,有时候会出现错误,或者说容器创建了,但是没有运行,也没有任何提示,通过本文列出的配置之后几乎就能解决,有时候配置文件没问题,出现了错误,可以尝试重启docker服务,如果在容器创建但是没有运行,也没有任何提示的情况下,我们可以把 -d 参数去掉,这样就能发现后台启动容器的时候是因为报错了,才没有运行容器,然后根据报错信息来解决问题
docker以配置文件方式启动redis容器的命令
docker run -p 7489:6379 -v /home/myredis/etc/redis/redis.conf:/etc/redis/redis.conf -v /home/myredis/data:/data --name myredis -d redis redis-server /etc/redis/redis.conf
如果出现启动后容器创建了但是没有运行的情况,需要注意以下情况:
配置文件版本问题,配置文件参数设置问题
重点注意:版本问题
我们拉取的redis的镜像中是没有redis.conf的,我们需要自己从网上下载一个,并且进行相关配置,
redis镜像版本必须要与redis.conf的版本保持一致,否则通过配置文件启动会报错,如果没有报错是因为启动方式是后台启动,以下网址可以下载linux各个版本的redis
http://download.redis.io/releases/
- daemonize
配置文件中,daemonize 默认为no,不需要修改为yes
因为改为yes表示以守护进程的方式启动redis,我们使用docker run启动命令的时候就不能使用-d了,因为-d这个参数也是表示以守护进程的方式启动redis容器,这两个配置会产生冲突,导致无法启动成功,也没有报错日志
- protected-mode
默认yes,要改为no,也是是保护模式,限制为本地访问,修改为no后解除保护模式
- bind
bind 127.0.0.1 通过#注释掉,解除本地连接限制
- appendonly yes持久化(可选)
appendonly 默认是no,可以改为yes
- requirepass(设置密码)
建议设置密码
requirepass 你的密码
- redis.conf文件权限
最好修改主机的配置文件为最高权限,chomod 777 redis.conf
经过上述配置依旧无法启动成功,还需要注意以下问题:
1.开放容器对外映射的端口
2.开放端口之后,或者修改过其他端口配置,注意要重新启动dockers:systemctl restart docker
因为docker服务启动时会定义自定义链DOCKER,并且会与firewall底层的iptables进行关联,当我们对防火墙(firewall)操作的时候,可能会清除docker定义的自定义链,导致docker服务出现问题,最终导致启动docker报错,所以在我们修改防火墙配置之后,我们就需要通过命令systemctl restart docker重启docker,重启 docker服务就可以重新生成自定义链docker