一、拉取官方5.0.3镜像
下载完成
1
2
3
4
5
6
7
8
9
10
|
[root@localhost ~] # docker pull redis:5.0.3 5.0.3: pulling from library /redis f7e2b70d04ae: pull complete 421427137c28: pull complete 4af7ef63ef0f: pull complete b858087b3517: pull complete 2aaf1944f5eb: pull complete 8270b5c7b90d: pull complete digest: sha256:4be7fdb131e76a6c6231e820c60b8b12938cf1ff3d437da4871b9b2440f4e385 status: downloaded newer image for redis:5.0.3 |
二、创建挂载目录
1、创建挂载文件夹
1
2
3
4
|
[root@localhost ~] # mkdir -p /root/redis/data /root/redis/conf [root@localhost ~] # cd redis/ [root@localhost redis] # ls conf data |
2、创建redis.conf
在/root/redis/conf目录中创建文件 redis.conf
1
|
touch redis.conf |
显示目录
1
2
3
4
5
6
|
[root@localhost redis] # cd conf/ [root@localhost conf] # ls [root@localhost conf] # touch redis.conf [root@localhost conf] # ls redis.conf [root@localhost conf] # |
三、创建redis 容器
1
|
docker run -d --name redis -p 6379:6379 - v /root/redis/conf/redis .conf: /redis .conf - v /root/redis/data : /data redis:5.0.3 redis-server --appendonly yes |
参数说明:
-d 后台运行
-p 端口映射到主机的端口
-v 将主机目录挂载到容器的目录
redis-server --appendonly yes : 在容器执行redis-server启动命令,并打开redis持久化配置
1、启动redis
启动中报错如下:
1
2
3
4
|
[root@localhost ~] # docker run -d --name redis -p 6379:6379 -v /root/redis/conf/redis.conf:/redis.conf -v /root/redis/data:/data redis:5.0.3 redis-server --appendonly yes 9bc537c19ff0ad76727b5215da8cba4223c5ff97f1d9a53585d573ca71fd8c0c docker: error response from daemon: driver failed programming external connectivity on endpoint redis (fa297144f8d0c958288bb35a94ffbec545d348f2ff9f55a5b573f3d9a0354ace): (iptables failed: iptables --wait -t nat -a docker -p tcp -d 0 /0 --dport 6379 -j dnat --to-destination 172.17.0.3:6379 ! -i docker0: iptables: no chain /target/match by that name. ( exit status 1)). |
说明: docker服务启动时定义的自定义链docker由于某种原因被清掉
重启docker服务及可重新生成自定义链docker
解决方案:
第一步、重启docker;
第二步、启动容器;
1
2
|
systemctl restart docker docker start foo |
2、容器创建成功,启动redis容器
1
|
docker start redis |
1、启动失败问题:启动容器就会出现iptables: no chain/target/match by that name出错
粗暴解决方案
重启docker
2、正常启动启动显示
四、客户端连接
我用的 redisdesktopmanager
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://segmentfault.com/a/1190000021274293