docker
1docker pull 镜像
2docker ps -a 查看所有容器
docker image 查看镜像3docker rm 容器id 删除容器
docker rm 一次可以指定多个容器,如果希望批量删除所有已经退出的容器,可以执行如下命令:
docker rm -v $(docker ps -aq -f status=exited) docker rmi 镜像id 删除镜像4docker exec -it 容器名字 /bin/bash 进入容器内
docker exec -it 容器名 ifconfig 不必进入 直接执行命令docker attach 容器名 进入容器5docker commit id号 镜像名字 将容器修改后生成新的镜像
6docker build -t test/tomcat:8.5.30 . 根据Dockerfile 创建镜像
vim DockerfileFROM docker.io/openshift/base-centos7LABEL maintainer='test'
RUN yum update -y && \
yum install -y net-tools && \ # yum clean all yum -y install java-1.8.0-openjdk-devel.x86_64 &&\curl -Ljk https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.34/bin/apache-tomcat-8.5.34.tar.gz | tar zxf - && \
mv apache-tomcat-8.5.34 /tomcatCMD ['/tomcat/bin/catalina.sh','run']COPY localtime /etc6docker run -dit -p 80:8080 --name 镜像id号 /bin/bash 根据镜像创建容器
7docker cp 容器与本地复制文件
docker exec centos_7 ls /tmpdocker cp centos_7:/tmp/yum.log .lldocker cp yum.log centos_7:/docker exec centos_7 ls /8docker create 创建一个新容器不启动
docker create centos_79docker diff 查看容器内更改的文件或者文件夹
docker diff centos_710docker events 查看docker服务端的一些信息
docker events11docker exec 容器内执行命令
docker exec centos_7 hostname 在bash终端操作命令docker exec -it centos_7 /bin/bash 进入容器内操作12 docker export 将容器文件系统导出
docker export centos_7 -o(>) centos-7.tar -o指定名称13 docker history 容器操作历史命令
14docker import 将导出的文件系统创建一个镜像
docker import centos-7.tar centos:7-newdocker run -it centos:7-new /bin/bash15 docker info docker当前系统的容器的信息
docker inspect16 docker kill
docker load 从文件导入到镜像 docker save 导出到文件 docker load -i 文件17docker login 登陆仓库
docker login -u admin -p密码 地址docker logout docker logout 推出官方docker logout 地址 私有地址18docker logs centos_7 显示容器日志
19Docker 命令: pause unpause 多个容器暂停
20Docker 命令: port 列出容器的端口映射
21Docker 命令: ps -f /-a /-l
22Docker 命令: pull and push 镜像拉取/推送镜像
23Docker 命令: run
docker run -d docker run -it --rm docker run -dit -p 80:8080 --name 镜像id号 /bin/bash 根据镜像创建容器24Dockerfile 文件介绍
docker构建镜像的方法: commit、dockerfile
1、使用commit来构建镜像:
commit是基于原有镜像基础上构建的镜像,使用此方法构建镜像的目的:保存镜像里的一些配置信息和修改的信息。相当于一个镜像的快照。2、使用dockerfile来构建镜像:
dockerfile是快速构建所需(自定义)镜像。dockerfile的指令:1 FROM:指定基础镜像(FROM是必备的指令,并且必须为第一条指令)。
2 RUN: 用来执行命令行命令。其基本格式:
shell格式: RUN <命令> ,输入在bash环境中的命令即可,一个dockerfile允许使用RUN不得超过127层,所以,使用一次RUN, 使用 ‘ \ ’ 换行,使用‘ && ’执行下一条命令。一般使用此种格式;
exec格式: RUN <"可执行文件", "参数1", "参数2">,此种方式像是函数调用中的格式;
3 COPY: 复制文件。 其基本格式:
格式1:COPY <源路径>...<目标路径>
格式2:COPY [“<源路径1>”,....."<目标路径>"]
4 ADD: 更高级的复制文件,在COPY的基础上增加了一些功能,如果复制的是压缩包的话,会直接解压,而不需要在使用RUN解压;
5 CMD:容器启动命令。其基本格式:
shell格式: CMD <命令>
exec格式: CMD ["可执行文件", "参数1", "参数2"...]
参数列表格式: CMD [“参数1”, “参数2”...],在指定了ENTRYPOINT指令后,用CMD指定具体的参数
6 ENTRYPOINT: 入口点。其基本格式分为exec和shell,
ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数。ENTRYPOINT在运行中可以替代,不过比CMD繁琐,需要通过docker run 的参数--entrypoint 来指定。
当指定了ENTRYPOINT后,CMD的含义就发生了改变,不在是直接运行其命令,而是将CMD的内容作为参数传递给ENTRYPOINT指令。其执行时就变成了: <ENTRYPOINT> "<CMD>"7 ENV: 设置环境变量。(都可以使用这里使用的变量)其基本格式:
格式1:ENV <key> <value>
格式2:ENV <key1>=<value1> <key2>=<value>...
8 ARG: 构建参数。构建参数和ENV的效果一样,都是设置环境变量,所不同的是ARG所构建的环境变量在将来容器运行时是不存在的。其基本格式:
格式1: ARG <参数名> [=<默认值>]
格式2: 该默认值可以在构建命令 docker build 中用 --build-arg <参数名>=<值> 来覆盖
9 VOLUME: 定义匿名卷。 其基本格式:
格式1: VOLUME ["<路径1>", "<路径2>"...]
格式2: VOLUME <路径>
10 EXPOSE: 暴露端口。EXPOSE指令是声明运行时容器所提供的端口,在启动容器时不会在因为这个声明而开启端口。 其基本格式:
格式1: EXPOSE <端口1> [<端口2>...]
11 WORKDIR: 指定工作目录。其基本格式:
格式1: WORKDIR <工作目录路径>
12 USER: 指定当前用户。USER是帮助你切换到指定用户。 其基本格式:
格式1: USER <用户名>
13 HEALTCHECK: 健康检查,判断容器的状态是否正常。 其基本格式:
格式1: HEALTCHECK [选项] CMD <命令> :设置检查容器健康状况的命令
格式2: HEALTCHECK NONE: 如果基础镜像有健康检查指令,使用此格式可以屏蔽掉其健康检查指令
例如构建nginx镜像[root@docker ~]# mkdir mynginx[root@docker ~]# cd mynginx/[root@docker mynginx]# pwd/root/mynginx[root@docker ~]# wget -P /root/mynginx/ http://nginx.org/download/nginx-1.15.2.tar.gz[root@docker mynginx]# vi Dockerfile#20181128#auther wang#test make nginx docker imagesFROM centosRUN ping -c 1 www.baidu.com #测试网络情况RUN yum -y install gcc make pcre-devel zlib-devel tar zlib #安装yum相关工具ADD nginx-1.15.2.tar.gz /usr/src/ #解压RUN cd /usr/src/nginx-1.15.2 \ #编译 && mkdir /usr/local/nginx \ && ./configure --prefix=/usr/local/nginx && make && make install \ && ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ \ && nginxRUN rm -rf /usr/src/nginx-1.15.2 #删除解压包EXPOSE 80 #映射端口
运行docker命令构建镜像:
[root@docker mynginx]#docker build -t nginx:v3 .启动自定义的镜像:[root@docker ~]#docker run -d -p 80:80 --name nginx nginx:v3注:这时,你无论怎么启动这个容器,它还是一直处于exited状态。经过各种解决,最终,终于知道问题出在了哪。 原来容器启动时,它是在后台对应着一个线程启动的,它在启动时是已经启动了,但它执行完命令后,就退出了,并没有在后台运行着,所以使用 -dit 参数让它在后台运行即可。[root@docker ~]#docker run -dit -p 80:80 --name nginx nginx:v3然而.......此时又出现了问题,它虽然起来了,但nginx的web网页界面访问不了,显示拒绝连接!!!!
[root@docker ~]# curl 192.168.100.22
curl: (7) Failed connect to 192.168.100.22:80; 拒绝连接[root@docker ~]# elinks --dump 192.168.100.22ELinks: 拒绝连接然后,又经过问百度,FQ看谷歌,终于找到了问题的所在。原来只要使用 exec 进入到容器里启动nginx就可以了。[root@docker ~]# docker exec -it nginx bash
[root@ecaafe119044 /]# nginx[root@ecaafe119044 /]# exitexit