zoukankan      html  css  js  c++  java
  • Docker各种零散命令整理

    • Docker 环境搭建

      • Docker所依赖的包环境
    yum install -y yum-utils device-mapper-persistent-data lvm2
    
      • 更新Docker yum源,并安装
        • 方式一:下载阿里云Docker社区版 yum
    [root@localhost ~]# cd /etc/yum.repos.d/
    [root@localhost yum.repos.d]# wget http://mirrors.aliyun.com/dockerce/linux/centos/docker-ce.repo
    
        • 查看Docker安装包
    yum list | grep docker
    

      

        • 方式二:添加Docker-ce 阿里源镜像
    yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    

      

        • 如果使用yum-config-manager添加yum源,执行如下,更新yum软件包
    yum makecache fast
    

      

      • 安装Docke-ce,默认安装最新版本
    yum -y install docker-ce
    

      

      • 查看其它版本,之后使用yum install命令后面带版本号即可下载
    yum list docker-ce.x86_64 --showduplicates
    

      

      • 启动Docker
    systemctl start docker.service 
      • 设置开机启动Docker
    systemctl enable docker
    

      

      • 更新xfsprogs
    yum -y update xfsprogs
    

      

      • 设置镜像加速

      阿里云镜像加速器配置地址:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors,不过这个需要注册阿里云账号;

      如果不想注册阿里云账号,可以使用中科大的加速器;[http://mirrors.ustc.edu.cn/help/dockerhub.html?highlight=docker]

      设置完成后,执行以下命令重启Docker;

    systemctl daemon-reload && systemctl restart docker
    
    • 查看本地镜像

    docker images
    

      

    • 搜索镜像

    docker search 镜像名
    

      

    • 搜索镜像并过滤是官方的

     docker search --filter "is-official=true" 镜像
    

     

    • 搜索镜像并过滤大于多少颗星的

    docker search --filter stars=stars数量 镜像名 
    

      

    • 下载镜像

    docker pull 镜像名:tag
    

      

    • 修改本地镜像名字(小写)

    docker tag 旧镜像名 新镜像名
    

      eg: docker tag centos:7 mycentos:1

      

    • 本地镜像的删除

    docker rmi IMAGE_ID
    
    • 构建容器

    docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
    
    OPTIONS:
    -a: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项
    -d: 后台运行容器,并返回容器ID
    -i: 以交互模式运行容器,通常与 -t 同时使用
    -P: 随机端口映射,容器内部端口随机映射到主机的端口
    -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
    -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用
    --name="": 为容器指定一个名称
    --dns: 指定容器使用的DNS服务器,默认和宿主一致
    --dns-search: 指定容器DNS搜索域名,默认和宿主一致
    -h "": 指定容器的hostname
    -e: 设置环境变量
    --env-file=[]: 从指定文件读入环境变量
    --cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行
    -m :设置容器使用内存最大值
    --net="": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型
    --link=[]: 添加链接到另一个容器
    --expose=[]: 开放一个端口或一组端口
    --volume , -v: 指定挂载路径
    
    • 查看本地所有的容器

    docker ps -a
    

      

    • 查看本地正在运行的容器  

    docker ps
    

      

    • 停止容器

    docker stop CONTAINER_ID / CONTAINER_NAME
    

      

    • 一次性停止所有容器

    docker stop $(docker ps -a -q)
    

      

    • 一次性启动所有容器

    docker start $(docker ps -a -q)
    

      

    • 启动容器

    docker start  CONTAINER_ID / CONTAINER_NAME
    

      

    • 重启容器

    docker restart CONTAINER_ID / CONTAINER_NAME
    

      

    • 删除容器

    docker rm CONTAINER_ID / CONTAINER_NAME
    

      

    • 强制删除容器

    docker rmi -f CONTAINER_ID / CONTAINER_NAME
    

      

    • 查看容器详细信息

    docker inspect CONTAINER_ID / CONTAINER_NAME
    

      

    • 进入容器

    docker exec -it CONTAINER_ID  /bin/bash  
    

      注:路径需要绝对路径, ":"之间不能有空格

    • 从宿主机复制到容器

    docker cp 宿主机本地路径 容器名字/容器ID:容器路径
    

      

    • 从容器复制到宿主机

    docker cp 容器名字/容器ID:容器路径 宿主机本地路径
    

      

    • 宿主机文件夹挂载到容器里(只能在构建时使用
    docker run -itd -v 宿主机路径:容器路径 镜像名:tag
    

      参考:[https://docs.docker.com/engine/reference/commandline/run/]

    • Commit构建自定义镜像

      构建镜像:

    docker commit [-a ""] [-m ""] CONTAINER_ID IMAGE_NAME:tag
    

      -a:标注作者

      -m:说明注释

      CONTAINER_ID:基于哪个容器的ID

    • 常用的Dockerfile指令

      FROM:基于哪个镜像;

      MAINTAINER:注明作者;

      COPY:复制文件进入镜像(只能用相对路径,不能用绝对路径);

      ADD:复制文件进入镜像,假如文件是.tar.gz文件会解压;

      WORKDIR:指定工作目录,假如路径不存在会创建路径;

      ENV:设置环境变量;

      EXPOSE:暴露容器端口;

      VOLUME

        用于容器数据挂载到宿主机;

        在dockerfile里设置volume是无法修改宿主机的挂载路径的;

        使用 --volumes-from 实现容器与容器之间volume共享;

        eg:

      • 创建nginx1
    docker run -itd -p 8080:80 -v /usr/local/nginx/html:/usr/local/nginx/html --name nginx1
    mycentos:nginx /usr/local/nginx/sbin/nginx -g "daemon off;"
    
      • 创建nginx2
    docker run -itd -p 8081:80 --volumes-from nginx1 --name nginx2 mycentos:nginx
    /usr/local/nginx/sbin/nginx -g "daemon off;"
    
      • 创建nginx3      
    docker run -itd -p 8082:80 --volumes-from nginx1 --name nginx3 mycentos:nginx
    /usr/local/nginx/sbin/nginx -g "daemon off;"
    

      RUN:在构建镜像的时候执行,作用于镜像层面;

      ENTRYPOINT:在容器启动的时候执行,作用于容器层,dockerfile里有多条时只允许执行最后一条

      CMD

       在容器启动的时候执行,作用于容器层,dockerfile里有多条时只允许执行最后一条容器启动后执行默认的命令或者参数,允许被修改;

       注:ENTRYPOINT优先于CMD执行

      

      命令格式:

      eg:

        shell命令格式:

    RUN yum install -y net-tools

     

        exec命令格式:

    RUN [ "yum","install" ,"-y" ,"net-tools"]
    

      

      构建:

    docker build -t  IMAGE_NAME:tag [dockerfile路径]
    

      IMAGE_NAME:新建的镜像名

      tag:新建镜像的tag

      参考:[https://docs.docker.com/engine/reference/builder/

      Nginx镜像启动注意事项:

        /usr/local/nginx/sbin/nginx 在容器里Nginx是以daemon方式启动,退出容器时,Nginx程序也会随着停止;   

      解决方式:

        需要使用前台方式永久运行:/usr/local/nginx/sbin/nginx -g "daemon off;"

    • docker镜像过大

      • 串联 Dockerfile 指令,在 Dockerfile 中, 每一条指令都会创建一个镜像层,会增加整体镜像的大小;合并多个指令串起来执行,Dockerfile 中的 RUN 指令通过 && 和 /支持将命令串联在一起,可以省不少镜像层;
      • 选用更小的基础镜像,比如运行spring cloud项目,不必用jdk,直接选用jre镜像即可,可以节省50%的内存甚至更多;
    • docker-compose

      docker compose是用于定义和运行多容器Docker应用程序的工具,通过Compose,可以使用yaml文件来配置应用程序需要的所有服务;

      安装:

    curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
    chmod +x /usr/local/bin/docker-compose
    ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
    docker-compose --version
    

      

      命令:

    后台启动容器:docker-compose up -d
    查看容器运行情况:docker-compose ps
    停止并删除容器:docker-compose down
    停止并删除容器并删除volume:docker-compose down --volumes
    停止容器:docker-compose stop
    启动容器:docker-compose start

      操作docker-compose一定要在配置文件docker-compose.yml文件路径下操作,格式一定要注意有空格;

  • 相关阅读:
    (转载)SAPI 包含sphelper.h编译错误解决方案
    C++11标准的智能指针、野指针、内存泄露的理解(日后还会补充,先浅谈自己的理解)
    504. Base 7(LeetCode)
    242. Valid Anagram(LeetCode)
    169. Majority Element(LeetCode)
    100. Same Tree(LeetCode)
    171. Excel Sheet Column Number(LeetCode)
    168. Excel Sheet Column Title(LeetCode)
    122.Best Time to Buy and Sell Stock II(LeetCode)
    404. Sum of Left Leaves(LeetCode)
  • 原文地址:https://www.cnblogs.com/coder-zyc/p/14608939.html
Copyright © 2011-2022 走看看