DockerFile制作自己的Redis镜像
hub.docker.com 搜索到的 Redis官方镜像,提示我们可以创建自己的 DockerFile 来添加 redis.conf 文件:
于是,我准备进行首次 DockerFile 的制作尝试。
一、准备工作
1.1 下载 redis.conf
我的方案是从 GitHub 上下载 redis.conf。我选择了 5.0.14 版本,各位可以选择自己需要的版本。
1.2 修改配置
1.2.1 注释掉bind 127.0.0.1
# bind 127.0.0.1
关于 bind 127.0.0.1
,Redis的bind的误区 讲得挺好的:
bind <ip>
是绑定本机的IP地址,(准确的是:本机的网卡对应的IP地址,每一个网卡都有一个IP地址)- 127.0.0.1 是一个回环地址(Local Loopback),也就是只有本地才能访问到这个回环地址,而其他的计算机也只能访问他们自己的回环地址。
如果配置 bind 127.0.0.1
,那就只有本机可以访问,而其他计算机不能访问。因此,我们在 redis.conf 中注释掉这一行
1.2.2 修改daemonize no
daemonize no
daemonize 表示是否以守护进程运行,在构建 Docker 镜像中如果设置为 daemonize yes,会导致启动后立即自动关闭,用 docker ps 命令查询不到进程,
且用 docker logs 容器id/容器名称 查询日志时,也没有报错,而是以下内容:
1:C 17 Jan 2022 11:29:12.523 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
1:C 17 Jan 2022 11:29:12.524 # Redis version=5.0.14, bits=64, commit=00000000, modified=0, pid=1, just started
1:C 17 Jan 2022 11:29:12.524 # Configuration loaded
1.2.3 增加密码验证
打开 requirepass 和 masterauth 的注释:
requirepass abc123
masterauth abc123
开启 requirepass 要求客户端在处理任何其他命令之前发出 AUTH
开启 masterauth ,如果主机受密码保护(开启了 requirepass 配置指令),则可以在启动复制同步过程之前通知复制副本进行身份验证,否则主机将拒绝复制副本请求。
二、构建Dockerfile
2.1 文件结构
geekziyu-redis
├── Dockerfile
└── redis.conf
geekziyu-redis 是我 Windows 电脑的文件夹: D:\DockerContainer\geekziyu-redis
2.2 Dockerfile
注意,文件名为 Dockerfile:D 要大写,f 要小写,且不带文件后缀。
FROM redis:5.0.14
MAINTAINER geekziyu@163.com
COPY redis.conf /usr/local/etc/redis/redis.conf
EXPOSE 6379
CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ]
2.3 build
docker build -t geekziyu/redis:latest .
注意末尾这个 .
,省略它会报错。
之后,用
docker images
检查镜像,发现多出 geekziyu/redis
2.4 run
运行镜像,启动进程:
docker run -it --name ziyuredis -p 6379:6379 -d geekziyu/redis:latest
如果不加上 -p 6379:6379
,那么宿主机是访问不了的。
三、验证
打开 Bash :
docker exec -it ziyuredis /bin/bash
接着运行 redis-cli,并验证密码:
root@ae284054ebc8:/# redis-cli
127.0.0.1:6379> auth abc123
至此,我们就使用 Dockerfile 简单的构建了一个Redis镜像并用此镜像运行了一个进程。