1)##Docker常用命令
docker --help
docker images [-a] [-q] [--digests]
docker images -f $(docker images -qa) :清空镜像
docker ps -lq [-l] 上次运行的容器 [-n] 上几次运行的容器
关闭容器
# docker stop [ID] 正常关闭
# docker kill [ID] 强制关闭
# docker inspect [ID] 获取容器/镜像的元数据
# 启动容器
docker run -d centos /bin/sh -c "while true; do ehco hello doing;sleep 2;done"
##进入容器
docker exec -t [ID] ls -l /tmp
docker attach [ID]
age: docker exec -it [ID] /bin/bash
2)容器数据卷
docker run -it -v /宿主机文件夹路径 :/容器文件夹路径 镜像名(ID)
docker run -it -v /宿主机文件夹路径 :/容器文件夹路径:ro 镜像名(ID) {容器内文件只读,不能写、改操作}
3)Dockerfile
#volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,------------success"
CMD /bin/bash
# --privileged=true
# docker build -f /myDocker/Dockerfile -t stan/centos .
Dockerfile2
FROM centos
MAINTAINER STAN<stan@163.com>
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
VOLUME ["/data"]
CMD echo "finished,------------success"
EXPOSE 80
CMD echo $MYPATH
CMD echo "success --------------ok"
CMD /bin/bash
# docker build -f /myDocker/Dockerfile2 -t mycentos:1.2 .
4)数据卷容器(--volumes-from 数据共享)
docker run -it --name dc01 stan/centos
docker run -it --name dc02 --volumes-from dc01 stan/centos
5)dockerfile保留字指令
FROM:基础镜像,当前新镜像是基于哪个镜像的
MAINTAINER:镜像维护者的姓名和邮箱地址
RUN:容器构建时需要运行的命令
EXPOSE:当前容器对外暴露的端口号
WORKDIR:指定在容器创建后,终端默认登录进来工作目录,一个落脚点
ENV:用来在构建镜像过程中设置环境变量。
举例:ENV MY_PATH /usr/mytest
ENV这个环境变量可以在后续的任何RUN指令中使用,这就如同在命令前指定了环境变量前缀一样;
也可以在其他指令中直接使用这些环境变量,比如WORKDIR $MY_PATH
ADD:将宿主机目录下的文件拷贝到镜像里面并且ADD命令会自动处理URL和解压tar压缩包
COPY:类似ADD,拷贝文件和目录到镜像中,但是它只是拷贝,不会自动处理URL和解压tar压缩包。
COPY将从构建上下文目录中<源路径>的文件/目录复制到新的一层的镜像内的<目标路径>位置。
它的使用方法有两种:COPY src test和COPY ["src","dest"]
VOLUME:容器数据卷,用于数据保存和持久化工作
CMD:指定一个容器启动时要运行的命令。dockerfile中可以有多个CMD指令,但只有最后一个生效,CMD会被docker run之后的参数替换。
CMD指令的格式和RUN类似,也是两种格式:
a) shell格式:CMD <命令>
b) exec格式:CMD ['可执行文件',‘参数1’,‘参数2’....]
c) 参数列表格式:CMD ['参数1',‘参数2’...],在指定了ENTRYPOINT指令后,用CMD指定具体的参数。
ENTRYPOINT:指定一个容器启动时要运行的命令。ENTRYPOIT的目的和CMD一样,都是在指定容器启动程序及参数。
区别:CMD和ENTRYPOINT都是指定一个容器启动时要运行的命令,但是 如果dockerfile中可以有多个CMD指令,只有最后一个生效 ,CMD会被docker run之后的参数替换 ;
而有多个ENTRYPOINT指令,每个指令都生效,这就是CMD和ENTRYPOINT的区别。
ONBUILD(触发器) :当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后,父镜像的onbuild被触发。
6) 镜像变更历史
docker history [ID]
7) CMD 和 ENTRYPOINT 的区别
FROM centos
RUN yum install -y curl
CMD ["curl","-s","http://ip.cn" ]
FROM centos
RUN yum install -y curl
ENTRYPOINT ["curl","-s","http://ip.cn" ]
##docker run myip2 -i
8)配置自己的centos环境
FROM centos
COPY c.txt /usr/local/copy.txt
#把java与tomcat添加到容器中
ADD jdk-8u191-linux-x64.tar.gz /usr/local
ADD apache-tomcat-9.0.14.tar.gz /usr/local
#安装vim 编辑器
RUN yum -y install vim
#设置工作访问的workdir路径
ENV MYPATH /usr/local
WORKDIR $MYPATH
#配置java与tomcat环境变量
ENV JAVA_HOME /usr/local/jdk1.8.0_191
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.14
ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.14
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
## 容器运行时端口
EXPOSE 8080
CMD ./usr/local/apache-tomcat-9.0.14/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.14/bin/logs/catalina.out
docker run -it -p8888:8080 -d --name tomcat0 -v /home/tomcat/test:/usr/local/apache-tomcat-9.0.14/webapps/test -v /home/tomcat/logs:/usr/local/apache-tomcat-9.0.14/logs --privileged=true tomcat /bin/bash