经过Docker pull命令能够把Registry上的docker镜像,下载到服务器本地php
经过docker push命令能够把服务器本地的docker镜像,上传到Registry上前端
Registry在构建自动化平台,起着很是重要的做用!python
提示:Docker镜像运行以后会成为Docker容器----经过 docker run命令mysql
1.磁盘占用空间小,由于docker镜像采用了分层技术,构建的镜像大小,只有自身的大小,不包含父镜像的大小linux
2.内存消耗少,docker容器共享的宿主机的内核,没有操做的进程消耗c++
git clone https://git.oschina.net/*YOURNAME*/docker-training.git
,将你的远程仓库clone到服务器Git 使用指南git
后续会构建4个docker镜像,分别为:github
centos7 (基础镜像)sql
worpdress(应用镜像)
Dockerfile是自动构建docker镜像的配置文件,Dockerfile中的命令很是相似Linux shell下的命令
Dockerfile,可让用户自定义构建docker镜像,支持以 # 开头的注释行
通常,Dockerfile分为4部分
方便经过自动化平台,自动构建docker镜像
# # MAINTAINER Carson,C.J.Zeong <zcy@nicescale.com> # DOCKER-VERSION 1.6.2 # # Dockerizing CentOS7: Dockerfile for building CentOS images # FROM centos:centos7.1.1503 MAINTAINER Carson,C.J.Zeong <zcy@nicescale.com> ENV TZ "Asia/Shanghai" ENV TERM xterm ADD aliyun-mirror.repo /etc/yum.repos.d/CentOS-Base.repo ADD aliyun-epel.repo /etc/yum.repos.d/epel.repo RUN yum install -y curl wget tar bzip2 unzip vim-enhanced passwd sudo yum-utils hostname net-tools rsync man && \ yum install -y gcc gcc-c++ git make automake cmake patch logrotate python-devel libpng-devel libjpeg-devel && \ yum install -y --enablerepo=epel pwgen python-pip && \ yum clean all RUN pip install supervisor ADD supervisord.conf /etc/supervisord.conf RUN mkdir -p /etc/supervisor.conf.d && \ mkdir -p /var/log/supervisor EXPOSE 22 ENTRYPOINT ["/usr/bin/supervisord", "-n", "-c", "/etc/supervisord.conf"]
FROM centos:centos7.1.1503
基于父镜像构建其余docker镜像,父镜像:能够经过docker pull 命令得到,也能够本身制做
MAINTAINER Carson,C.J.Zeong <zcy@nicescale.com>
Dockerfile维护者
ENV TZ "Asia/Shanghai"
ENV(environment)设置环境变量,一个Dockerfile中能够写多个。以上例子是:设置docker容器的时区为Shanghai
ADD aliyun-mirror.repo /etc/yum.repos.d/CentOS-Base.repo
拷贝本地文件到docker容器里,还能够拷贝URL连接地址下的文件,ADD还具备解压软件包的功能(支持gzip, bzip2 or xz)
COPY test /mydir
拷贝本地文件到docker容器
RUN yum install -y curl wget....
RUN命令,很是相似linux下的shell命令
(the command is run in a shell - /bin/sh -c - shell form)
在Dockerfile中每执行一条指令(ENV、ADD、RUN等命令),都会生成一个docker image layer
RUN pip install supervisor
supervisor进程管理系统,推荐使用
ADD supervisord.conf /etc/supervisord.conf
添加supervisor的主配置文件,到docker容器里
RUN mkdir -p /etc/supervisor.conf.d
建立存放启动其余服务"supervisor.conf"的目录,此目录下的全部以.conf结尾的文件,在启动docker容器的时候会被加载
EXPOSE 22
端口映射
EXPOSE <host_port>:<container_port>
推荐使用
docker run -p <host_port>:<container_port>
来固化端口
ENTRYPOINT ["/usr/bin/supervisord", "-n", "-c", "/etc/supervisord.conf"]
一个Dockerfile中只有最后一条
ENTRYPOINT
生效,而且每次启动docker容器,都会执行ENTRYPOINT
docker build
指令来生成docker镜像docker build -t csphere/centos:7.1 .
若是Dockerfile在当前目录下,输入点
.
就能够进行加载当前目录下的Dockerfile
若是不在当前目录下须要运行
docker build -t csphere/centos:7.1 <Dockerfile_dir>
加载相对路径下的Dockerfile
docker镜像的命名规则 registry_url/namespace/image_name:tag
默认tag
是latest
在构建Docker镜像时,若是有本身内部的yum源,替换成本身内部的yum源地址,能够加快构建速度。
若是第一次构建失败,会有部分镜像layer生成,第二次构建会基于第一次构建所生成的layer(use cache),继续构建
Step 10 : EXPOSE 22 ---> Running in 0ed1c5479ebc ---> c57a5bac41c8 Removing intermediate container 0ed1c5479ebc Step 11 : ENTRYPOINT /usr/bin/supervisord -n -c /etc/supervisord.conf ---> Running in e16c7ac2fd45 ---> 185ef7b101a8 Removing intermediate container e16c7ac2fd45 Successfully built 185ef7b101a8
能够看到每执行一条Dockerfile
的指令都会生成一个镜像的layerc57a5bac41c8
185ef7b101a8
最后185ef7b101a8
这个是docker镜像的ID,185ef7b101a8
是由c57a5bac41c8
185ef7b101a8
...layers叠加而成,体现了docker镜像是分层的
# docker images 查看当前主机本地有哪些docker镜像 REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE csphere/centos 7.1 185ef7b101a8 40 minutes ago 451.9 MB
经过docker镜像生成一个docker容器
docker help run
#查看docker run
命令的使用方法
docker run -it
#启动docker容器在前端 docker run -d
#启动docker容器在后台
docker run -p
docker run -P
在Dockerfile中有一条指令是EXPOSE 22,若是使用
-P
,宿主机会随机选择一个没有被使用的端口
和docker容器的22端口
作端口映射
,若是docker主机或者容器重启后,宿主机又会随机选择一个没有被使用的端口和docker容器的22端口作端口映射,这样端口会发生变化
若是使用
-p
,好比2222:22
,这样不论是docker主机或者容器重启后,2222:22端口都是这样来映射,不会发生改变
生成docker容器
docker run -d -p 2222:22 --name base csphere/centos:7.1
37ac69acf47d501ffc61d8883ae2ba362a132d11e46897212a92b1936e0a0593
参数说明:
查看Docker容器
docker ps
ps
默认只会显示容器在“running”的状态的,容器列表
docker ps -a
ps -a
会查看到全部的容器列表