一、引子
镜像和容器是不同的概念,本文主要是为了通过实践来强化对这两种不同概念的理解。
二、安装docker
安装docker,执行以下命令即可:
# 安装依赖
yum install -y yum-utils device-mapper-persistent-data lvm2
# 设置国内源
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 安装docker,默认最新版
yum -y install docker-ce
# 启动docker服务
systemctl start docker
# 设置自启动
systemctl enable docker
# 验证
docker -v
三、镜像实践
3.1、Dockerfile详解
请阅读我此前写的一篇博客:Dockerfile详解
3.2、Dockerfile构建镜像
我们以这个Dockerfile来举例(D不能小写):
FROM ubuntu
MAINTAINER docker_user docker_user@email.com
RUN apt-get update && apt-get install -y nginx
CMD ["nginx","-g","daemon off;"]
执行镜像
构建命令:
docker build -f Dockerfile -t nginx:v1 .
经过一通运行之后,镜像
够构建成功了
从该docker build命令中我们可以看出构建的镜像
名为nginx:v1,当然开发者也可以自己命名。从上述输出内容的先后顺序我们可以看出,docker构建镜像
是按照Dockerfile中开发者定义的命令由上至下依次执行的,且均会生成对应的层。我们可通过如下命令查看该镜像
的层:
3.3、docker commit构建镜像
除了通过Dockerfile构建镜像
,我们还可以通过docker commit命令构建镜像
,两者主要区别为生成镜像
的大小差异,通过Dockerfile构建的镜像
只有在docker build时才会增添新的资源,而docker commit基本上是获取运行中的容器
快照保存为镜像
,如果运行的容器
正在生成大量日志或更新包文件,那么当docker commit后这些数据会被保存至镜像
中,因而通常docker commit构建的镜像
相对Dockerfile构建的要大一些。
下面我们通过docker commit命令构建上述nginx:v1镜像
,在此之前,我们需要先将镜像
启动为容器
,如下所示:
通过docker exec命令进入容器
并安装网络配置工具net-tools,如下所示:
然后退出容器
,在宿主机上通过docker commit构建一个名为nginx:v2的新镜像
,如下所示:
3.4、镜像的其他操作
镜像
查看:
docker images
# 得到REPOSITORY、TAG、IMAGE ID、CREATED、SIZE字段值,后续会用到
镜像
删除:
docker rmi <REPOSITORY>:<TAG>
镜像
上传:
# 给镜像打标签
docker tag <REPOSITORY>:<TAG> <仓库地址>/<项目名>/<REPOSITORY>:<TAG>
# 镜像上传
docker push <仓库地址>/<项目名>/<REPOSITORY>:<TAG>
镜像
拉取:
# 拉取私有仓库镜像
docker pull <仓库地址>/<项目名>/<REPOSITORY>:<TAG>
# 拉取官方镜像仓库的镜像
docker pull <REPOSITORY>:<TAG>
镜像
的压缩:
docker save nginx:v1 > /tmp/nginx.tar
镜像
的导入:
docker load < /tmp/nginx.tar
四、容器实践
4.1、容器创建
通过docker run命令将构建的镜像
运行为容器
,具体命令如下:
docker run -dt --name nginx -p 8080:80 nginx:v1
其中:
-d
:代表docker将容器
在后台运行并输出该容器
ID;
-t
:代表docker为该容器
分配一个虚拟终端;
--name
:代表为容器
取一个名字;
-p
:代表设置该容器
的端口映射,其中冒号左边代表宿主机映射端口,右边代表容器
端口,容器
端口也是Dockerfile中设置的暴露端口;
nginx:v1
: 代表通过此镜像
启动容器
。
其它命令查看:
docker run --help
4.2、容器执行
在应用开发过程中,我们不可避免要进入容器
并进行相应调试,Docker的相应的命令如下:
docker exec -it 422 /bin/bash
其中:
-t
:代表分配一个伪终端;
-i
:代表保持交互模式;
422
:代表容器
ID,只要是能够证明唯一就可以,不用全输入;
/bin/bash
:代表以bash方式与容器
进行交互;
其它命令查看:
docker exec --help
4.3、容器删除
删除容器
命令:
docker rm <CONTAINER ID>
强制删除容器
命令:
docker rm -f <CONTAINER ID>
4.4、停止运行的容器
停止运行的容器
命令:
docker stop <CONTAINER ID>
4.5、容器查看
查看正在运行的容器
:
docker ps
查看所有容器
(包括正在运行的以及停止运行的):
docker ps -a
查看单一容器
:
docker inspect <CONTAINER ID>
查看容器
日志:
docker logs <CONTAINER ID>