• docker 常用命令[转载]


    作者: DeepInThought
    出处: https://www.cnblogs.com/DeepInThought

    1、Docker容器信息

    ##查看docker容器版本
    docker version
    ##查看docker容器信息
    docker info
    ##查看docker容器帮助
    docker --help
    

    2、镜像操作

    提示:对于镜像的操作可使用镜像名、镜像长ID和短ID。

    2.1、镜像查看

    ##列出本地images
    docker images
    ##含中间映像层
    docker images -a
    

    ##只显示镜像ID
    docker images -q
    ##含中间映像层
    docker images -qa   
    

    ##显示镜像摘要信息(DIGEST列)
    docker images --digests
    ##显示镜像完整信息
    docker images --no-trunc
    

    ##显示指定镜像的历史创建;参数:-H 镜像大小和日期,默认为true;--no-trunc  显示完整的提交记录;-q  仅列出提交记录ID
    docker history -H redis
    

    2.2、镜像搜索

    ##搜索仓库MySQL镜像
    docker search mysql
    ## --filter=stars=600:只显示 starts>=600 的镜像
    docker search --filter=stars=600 mysql
    ## --no-trunc 显示镜像完整 DESCRIPTION 描述
    docker search --no-trunc mysql
    ## --automated :只列出 AUTOMATED=OK 的镜像
    docker search  --automated mysql
    

    2.3、镜像下载

    ##下载Redis官方最新镜像,相当于:docker pull redis:latest
    docker pull redis
    ##下载仓库所有Redis镜像
    docker pull -a redis
    ##下载私人仓库镜像
    docker pull bitnami/redis
    

    2.4、镜像删除

    ##单个镜像删除,相当于:docker rmi redis:latest
    docker rmi redis
    ##强制删除(针对基于镜像有运行的容器进程)
    docker rmi -f redis
    ##多个镜像删除,不同镜像间以空格间隔
    docker rmi -f redis tomcat nginx
    ##删除本地全部镜像
    docker rmi -f $(docker images -q)
    

    2.5、镜像构建

    ##(1)编写dockerfile
    cd /docker/dockerfile
    vim mycentos
    ##(2)构建docker镜像
    docker build -f /docker/dockerfile/mycentos -t mycentos:1.1
    

    3、容器操作

    提示:对于容器的操作可使用CONTAINER ID 或 NAMES。

    3.1、容器启动

    ##新建并启动容器,参数:-i  以交互模式运行容器;-t  为容器重新分配一个伪输入终端;--name  为容器指定一个名称
    docker run -i -t --name mycentos
    ##后台启动容器,参数:-d  已守护方式启动容器
    docker run -d mycentos
    

    注意:此时使用"docker ps -a"会发现容器已经退出。这是docker的机制:要使Docker容器后台运行,就必须有一个前台进程。解决方案:将你要运行的程序以前台进程的形式运行。

    ##启动一个或多个已经被停止的容器
    docker start redis
    ##重启容器
    docker restart redis
    

    3.2、容器进程

    ##top支持 ps 命令参数,格式:docker top [OPTIONS] CONTAINER [ps OPTIONS]
    ##列出redis容器中运行进程
    docker top redis
    ##查看所有运行容器的进程信息
    for i in  `docker ps |grep Up|awk '{print $1}'`;do echo  &&docker top $i; done
    

    3.3、容器日志

    ##查看redis容器日志,默认参数
    docker logs rabbitmq
    ##查看redis容器日志,参数:-f  跟踪日志输出;-t   显示时间戳;--tail  仅列出最新N条容器日志;
    docker logs -f -t --tail=20 redis
    ##查看容器redis从2019年05月21日后的最新10条日志。
    docker logs --since="2019-05-21" --tail=10 redis
    

    3.4、容器的进入与退出

    ##使用run方式在创建时进入
    docker run -it centos /bin/bash
    ##关闭容器并退出
    exit
    ##仅退出容器,不关闭
    快捷键:Ctrl + P + Q
    ##直接进入centos 容器启动命令的终端,不会启动新进程,多个attach连接共享容器屏幕,参数:--sig-proxy=false  确保CTRL-D或CTRL-C不会关闭容器
    docker attach --sig-proxy=false centos 
    ##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i  即使没有附加也保持STDIN 打开;-t  分配一个伪终端
    docker exec -i -t  centos /bin/bash
    ##以交互模式在容器中执行命令,结果返回到当前终端屏幕
    docker exec -i -t centos ls -l /tmp
    ##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端
    docker exec -d centos  touch cache.txt 
    

    3.5、查看容器

    ##查看正在运行的容器
    docker ps
    ##查看正在运行的容器的ID
    docker ps -q
    ##查看正在运行+历史运行过的容器
    docker ps -a
    ##显示运行容器总文件大小
    docker ps -s
    


    ##显示最近创建容器
    docker ps -l
    ##显示最近创建的3个容器
    docker ps -n 3
    ##不截断输出
    docker ps --no-trunc 
    

    ##获取镜像redis的元信息
    docker inspect redis
    ##获取正在运行的容器redis的 IP
    docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis
    

    3.6、容器的停止与删除

    ##停止一个运行中的容器
    docker stop redis
    ##杀掉一个运行中的容器
    docker kill redis
    ##删除一个已停止的容器
    docker rm redis
    ##删除一个运行中的容器
    docker rm -f redis
    ##删除多个容器
    docker rm -f $(docker ps -a -q)
    docker ps -a -q | xargs docker rm
    ## -l 移除容器间的网络连接,连接名为 db
    docker rm -l db 
    ## -v 删除容器,并删除容器挂载的数据卷
    docker rm -v redis
    

    3.7、生成镜像

    ##基于当前redis容器创建一个新的镜像;参数:-a 提交的镜像作者;-c 使用Dockerfile指令来创建镜像;-m :提交时的说明文字;-p :在commit时,将容器暂停
    docker commit -a="DeepInThought" -m="my redis" [redis容器ID]  myredis:v1.1
    

    3.8、容器与主机间的数据拷贝

    ##将rabbitmq容器中的文件copy至本地路径
    docker cp rabbitmq:/[container_path] [local_path]
    ##将主机文件copy至rabbitmq容器
    docker cp [local_path] rabbitmq:/[container_path]/
    ##将主机文件copy至rabbitmq容器,目录重命名为[container_path](注意与非重命名copy的区别)
    docker cp [local_path] rabbitmq:/[container_path]
    
  • 作者: DeepInThought
    出处: https://www.cnblogs.com/DeepInThought
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    HDU 1874 畅通工程续(dijkstra)
    HDU 2112 HDU Today (map函数,dijkstra最短路径)
    HDU 2680 Choose the best route(dijkstra)
    HDU 2066 一个人的旅行(最短路径,dijkstra)
    关于测评机,编译器,我有些话想说
    测评机的优化问题 时间控制
    CF Round410 D. Mike and distribution
    数字三角形2 (取模)
    CF Round410 C. Mike and gcd problem
    CF Round 423 D. High Load 星图(最优最简构建)
  • 原文地址:https://www.cnblogs.com/wspblog/p/12801167.html
  • Copyright © 2020-2023  润新知