安装redis的公式
docker run -p 6379:6379 --name redis6.2.6 --privileged=true -v /app/redis/redis.conf:/etc/redis/redis.conf -v /app/redis/data:/data -d redis:6.2.6 redis-server /etc/redis/redis.conf
我遇到的问题:
docker安装redis之后 一开始启动成功, 1.为了测试select的功能 我进行修改了redis.conf配置文件中的databases属性 改为了18 2. 然后我还进行交互并且添加数据了 并且成功了 但是后来就启动不成功了 !
在网上看了很多说法:
检查一下你启动容器的指令是不是加了-d
这个参数,如果添加了,那么redis.conf
文件中的daemonize
必须设置为no
,否则容器无法
启动
但是我查看了自己的redis.conf 发现确实不是这个问题
网上说redis启动失败的解决方法都是适用于压根没启动成功过的人
解决方法
万能做法 打印日志 重点看FATAL
docker logs redis6.2.6 #docker + logs + 容器名
最终查到了我的错误:
FATAL: Data file was created with a Redis server configured to handle more than 16 databases. Exiting #百度翻译之后: #致命错误:数据文件是使用配置为处理16个以上数据库的Redis服务器创建的。正在退出
所以我的问题出现在,我修改了redis.conf配置文件中的databases属性 改为了大于16的数字:18
然后我还进行了redis中数据的改动
步骤
1.找到redis.conf文件,修改了redis.conf中databases属性的值 改为默认的16
2.删除容器数据卷/app/redis/data中对应的data 即是删除在databases为18的情况下产生的数据(rm -f /app/redis/data)
3.重启
总结:
网上解决redis不可以开启的情况适用于redis根本一次也没有启动成功的情况 ,非常实用 !
而我这种问题是属于手贱的后果 !
不过学到了很多,遇到bug那么就打印日志进行分析 !