本次目标是用Centos 7的基础镜像做一个redis容器供开发人员在开发环境里蹂躏。
首先,创建一个叫redis-test的文件夹,在这个redis-test文件夹里建立一个Dockerfile,内容如下:
1
2
3
4
5
6
7
|
FROM centos:latest
MAINTAINER Chris Chan
"chenx1242@163.com"
ENV REFRESHED_AT 2017-02-16
RUN yum -y update && yum -y
install
epel-release && yum -y
install
redis && yum -y
install
net-tools
EXPOSE 6379
ENTRYPOINT [
"/usr/bin/redis-server"
]
CMD []
|
这里我们简单说一下整个Dockerfile的内容:
首先选择了基础镜像是centos的最新版,即centos 7,然后填写作者信息;
在yum这一块要注意,如果没有安装epel-release的话,是无法正常安装redis的,这是centos与ubuntu不一样的地方。至于后面又补充安装了net-tools是因为centos 7里不自带ifconfig命令,所以需要安装一下net-tools,这样就有了ifconfig了;
随即我们又开放了6379端口;
然后就是entrypoint和cmd,这两个命令的区别很重要,具体区别请看:http://cloud.51cto.com/art/201411/457338.htm 这篇文章。
然后我们就可以依照这个Dockfile去建立一个镜像,因为目的是要在“centos环境下建立一个redis”,那么我们这个镜像的名字就叫作lccentos/redis,具体操作就是在redis-test文件夹下执行#docker build -t lccentos/redis .。
然后根据这个镜像需要制作一个容器,容器的名字就叫redisforcentos,那么命令就是:#docker run -d -p 6379 --name redisforcentos lccentos/redis。
然后我们#docker ps -a看一下效果。
可见宿主机的32774端口和容器的6379端口“融为一体”,这个时候,我们测试一下这个redisforcentos的容器是否已经正常启动了redis。
而且对于Docker来说,可以多个docker对应宿主机的同一个端口,比如我这台机器搞了两个redis,两个容器都可以指向6379的端口,如图:
这里也说一下Dockerfile的优化原则:
1)ADD和VOLUME应该放在Dockerfile底部,因为它们相对比yum安装那些变化的更勤;
2)EXPOSE可以一口气对应多个端口,比如
EXPOSE 80 2003 2004 7002
的效果跟下面的效果一样;
EXPOSE 80 EXPOSE 2003 EXPOSE 2004 EXPOSE 7002
3)ADD的操作应该放在Dockerfile的最下面;
参考资料:http://dockone.io/article/255?spm=5176.100239.blogcont40494.25.8RXqDX
本文转自 苏幕遮618 51CTO博客,原文链接:http://blog.51cto.com/chenx1242/1898855