总结docker常用命令

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 &&\

扫描二维码关注公众号,回复: 4304357 查看本文章

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

猜你喜欢

转载自www.cnblogs.com/donghui521/p/10044668.html
今日推荐