zoukankan      html  css  js  c++  java
  • 总结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 &&

    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

  • 相关阅读:
    黑盒测试和白盒测试的区别
    alpha测试和beta测试的区别
    selenium退出语句区别
    QTP8.2--安装流程
    Xshell无法连接Linux虚拟机问题
    Linux-----centos6.2---安装Linux的流程
    MySql错误处理--错误代码和消息
    基于Linux系统--web环境搭建
    前端底层-作用域 this 原型笔试题练习
    前端底层-冒泡与捕获
  • 原文地址:https://www.cnblogs.com/donghui521/p/10044668.html
Copyright © 2011-2022 走看看