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 Dockerfile
FROM docker.io/openshift/base-centos7
LABEL 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 /tomcat
CMD ['/tomcat/bin/catalina.sh','run']
COPY localtime /etc
6docker run -dit -p 80:8080 --name 镜像id号 /bin/bash 根据镜像创建容器
7docker cp 容器与本地复制文件
docker exec centos_7 ls /tmp
docker cp centos_7:/tmp/yum.log .
ll
docker cp yum.log centos_7:/
docker exec centos_7 ls /
8docker create 创建一个新容器不启动
docker create centos_7
9docker diff 查看容器内更改的文件或者文件夹
docker diff centos_7
10docker events 查看docker服务端的一些信息
docker events
11docker 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-new
docker run -it centos:7-new /bin/bash
15 docker info docker当前系统的容器的信息
docker inspect
16 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 images
FROM centos
RUN 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/ \
&& nginx
RUN 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.22
ELinks: 拒绝连接
然后,又经过问百度,FQ看谷歌,终于找到了问题的所在。原来只要使用 exec 进入到容器里启动nginx就可以了。
[root@docker ~]# docker exec -it nginx bash
[root@ecaafe119044 /]# nginx
[root@ecaafe119044 /]# exit
exit