解决Redis容器使用redis.conf启动失败
本文实现功能 解决redis容器启动redis.conf时启动及失败 简单了解redis.conf的一些配置 认识docker run命令的参数
@TOC
学习redis.conf的配置文件
打开redis.conf后会看到很多的无用信息

命令cat redis.conf | grep -v "#" | grep -v "^$"

执行命令:cat redis.conf | grep -v "#" | grep -v "^$" ->redis-test.conf


- daemonize no :redis默认是不作为守护进程使用的,这也就是说为什么在你不修改配置文件时直接使用redis-server /redis/redis.conf 启动redis会直接显示一个服务,你在这个终端就没有办法操作其他,只能新开一个终端来连接redis
- requirepass foobared :redis默认是没有密码连接的,但是为了安全密码还是需要设置的
- bind 127.0.0.1:这个配置项一般是直接注释掉的,这个配置开启后就只有本机可以连接redis
以上几个配置信息就是本文所需要知道的三个配置信息
认识docker run命令的参数
docker run命令就是创建一个新的容器
以下是一个我创建容器使用的命令docker run -itd --restart="always" --name redis -v /usr/local/docker/data:/data -v /usr/local/docker/redis.conf:/etc/redis.conf --net mynetwork -p 6380:6379 --ip 172.10.0.2 redis:4.0 redis-server /etc/redis.conf
- i : 打开STDIN,用于控制台交互
- t :分配tty设备,该可以支持终端登录,默认为false
- d:指定容器运行于前台还是后台,默认为false
- v:给容器挂载存储卷,挂载到容器的某个目录
- --net:容器使用自己自定义的网络
- -p:是端口号
- --restart:指定容器停止后的重启策略 no:容器退出时不重启 on-failure:容器故障退出(返回值非零)时重启 always:容器退出时总是重启
解决redis容器启动redis.conf时启动及失败
当我们认识了redis.conf的几个参数和docker run的几个常用参数后,我们来进行解决这个使用redis.conf启动时直接就失败问题。
然后开始创建容器 有一部分伙伴会发现有一个错误WARNING: IPv4 forwarding is disabled. Networking will not work.

vim /usr/lib/sysctl.d/00-system.conf
添加以下代码net.ipv4.ip_forward=1
重新启动network命令systemctl restart network
在来执行一下就没有问题了


这个时候我们在回顾一下redis.conf里边是不是有一个daemonize no
这个参数是是否以守护进程执行,在开发过程中我们都会把这个配置开启 配置为yes 。
然后在回顾一下docker run命令里边有一个参数 -d
这个参数也是以守护进程执行。
这下应该就很清楚了,是redis.conf跟docker配置冲突了
打开配置文件把守护进程修改为no


docker exec -it redis /bin/bash
里边,就可以看到我们在连接redis-cli时需要输入密码,这也就是在redis.conf里边配置的。

转载自:https://juejin.cn/post/6844904178511249422