上一篇我们学习了容器的启动和常用的进入容器的方式,今天我们来看看如何控制容器起停以及容器删除操作。

一、stop、kill、start和restart

stop、kill命令都可以停止运行的容器,二者不同之处在于,stop是先给容器中的进程发送SIGTERM信号,一段时间后在发送SIGKILL信号,这样可以让进程在退出前做一些善后工作,这样显得更加优雅,而kill命令则是直接杀掉容器中的进程。

$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 6 minutes quizzical_hermann
:~$ sudo docker stop 82b049e20195
82b049e20195
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Exited (0) 2 seconds ago quizzical_hermann

大家可以看到当执行stop命令时,容器状态变为Exited。start命令就是让处于Exited状态的进程重新启动,它能够保留容器第一次启动时执行的参数:

$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Exited (0) 2 seconds ago quizzical_hermann
$ sudo docker start 82b049e20195
82b049e20195
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 2 seconds quizzical_hermann

restart命令是重启容器,本质上就是限制性stop在执行start命令,我们除了手动重启之外,在启动容器时可以通过设置--restart参数,确保我们容器当出现错误而停止时能够自动重启容器。

restart参数配置说明如下:

  • no:默认策略,在容器退出时不重启容器

  • on-failure:在容器非正常退出时(退出状态非0),才会重启容器

  • on-failure:3:在容器非正常退出时重启容器,最多重启3次

  • always:在容器退出时总是重启容器

  • unless-stopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

$ sudo docker run -d --restart=always  ubuntu:18.04 pwd
fb149d6e2bc1f07dece3410bfc62f5bcaf08f69bfef0bb65eaa205c2c9408bd3
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fb149d6e2bc1 ubuntu:18.04 "pwd" 8 seconds ago Restarting (0) 1 second ago heuristic_robinson
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 4 minutes quizzical_hermann
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fb149d6e2bc1 ubuntu:18.04 "pwd" 11 seconds ago Restarting (0) Less than a second ago heuristic_robinson
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 4 minutes quizzical_hermann
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fb149d6e2bc1 ubuntu:18.04 "pwd" 12 seconds ago Restarting (0) 2 seconds ago heuristic_robinson
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 4 minutes quizzical_hermann
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fb149d6e2bc1 ubuntu:18.04 "pwd" 14 seconds ago Restarting (0) 3 seconds ago heuristic_robinson
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 4 minutes quizzical_hermann

大家可以看到,当设置--restart=always时,只要容器退出就会自动重启。

二、pause和unpause操作

有时候我们可能只想让容器暂停一会儿以便于做一些简单维护性操作,这时候如果直接使用stop和start操作成本就太高了,这时我们可以使用pause和unpause命令,pause命令会暂停容器,此时容器不再使用CPU,只有当执行unpause命令时,容器才恢复运行:

$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 5 minutes quizzical_hermann
$ sudo docker pause 82b049e20195
82b049e20195
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 6 minutes (Paused) quizzical_hermann
$ sudo docker unpause 82b049e20195
82b049e20195
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 6 minutes quizzical_hermann

三、容器删除

当我们想要删除一个或多个容器时,可以使用rm命令,此命令参数不仅可以直接传递一个或多个容器ID,也可以通过传递表达式删除指定的某一类容器。

$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
96c8a885dd0d ubuntu:18.04 "pwd" 7 seconds ago Exited (0) 6 seconds ago silly_bell
4f43afe0f4b9 ubuntu:18.04 "pwd" 8 seconds ago Exited (0) 7 seconds ago recursing_mirzakhani
c66c61850c2c ubuntu:18.04 "pwd" 9 seconds ago Exited (0) 8 seconds ago naughty_kapitsa
386d785528fd ubuntu:18.04 "pwd" 10 seconds ago Exited (0) 9 seconds ago elated_chandrasekhar
91aec302789d ubuntu:18.04 "pwd" 11 seconds ago Exited (0) 10 seconds ago modest_cori
038ac31cf1cf ubuntu:18.04 "pwd" 11 seconds ago Exited (0) 10 seconds ago recursing_northcutt
e3fbc064330e ubuntu:18.04 "pwd" 12 seconds ago Exited (0) 11 seconds ago compassionate_mccarthy
46f8b71c40e8 ubuntu:18.04 "pwd" 14 seconds ago Exited (0) 13 seconds ago vibrant_swartz
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 10 minutes quizzical_hermann
$ sudo docker rm 96c8a885dd0d
96c8a885dd0d
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4f43afe0f4b9 ubuntu:18.04 "pwd" 29 seconds ago Exited (0) 28 seconds ago recursing_mirzakhani
c66c61850c2c ubuntu:18.04 "pwd" 30 seconds ago Exited (0) 29 seconds ago naughty_kapitsa
386d785528fd ubuntu:18.04 "pwd" 31 seconds ago Exited (0) 30 seconds ago elated_chandrasekhar
91aec302789d ubuntu:18.04 "pwd" 32 seconds ago Exited (0) 31 seconds ago modest_cori
038ac31cf1cf ubuntu:18.04 "pwd" 32 seconds ago Exited (0) 31 seconds ago recursing_northcutt
e3fbc064330e ubuntu:18.04 "pwd" 33 seconds ago Exited (0) 32 seconds ago compassionate_mccarthy
46f8b71c40e8 ubuntu:18.04 "pwd" 35 seconds ago Exited (0) 34 seconds ago vibrant_swartz
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 11 minutes quizzical_hermann
$ sudo docker rm 4f43afe0f4b9 c66c61850c2c
4f43afe0f4b9
c66c61850c2c
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
386d785528fd ubuntu:18.04 "pwd" 53 seconds ago Exited (0) 52 seconds ago elated_chandrasekhar
91aec302789d ubuntu:18.04 "pwd" 54 seconds ago Exited (0) 53 seconds ago modest_cori
038ac31cf1cf ubuntu:18.04 "pwd" 54 seconds ago Exited (0) 54 seconds ago recursing_northcutt
e3fbc064330e ubuntu:18.04 "pwd" 55 seconds ago Exited (0) 54 seconds ago compassionate_mccarthy
46f8b71c40e8 ubuntu:18.04 "pwd" 57 seconds ago Exited (0) 56 seconds ago vibrant_swartz
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 11 minutes quizzical_hermann
$ sudo docker rm -v $(sudo docker ps -aq -f status=exited)
386d785528fd
91aec302789d
038ac31cf1cf
e3fbc064330e
46f8b71c40e8
$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
82b049e20195 ubuntu:18.04 "top -b" 4 days ago Up 13 minutes quizzical_hermann

当然如果要删除所有退出的容器,也可以直接使用sudo docker rm $(sudo docker ps -a -q),虽然这个命令是要删除所有容器,但是运行中的容器一般是无法直接删除的,所以就可以确保只删除Exited的容器。

Docker 与 K8S学习笔记(五)—— 容器的操作(下篇)的更多相关文章

  1. ES6学习笔记<五> Module的操作——import、export、as

    import export 这两个家伙对应的就是es6自己的 module功能. 我们之前写的Javascript一直都没有模块化的体系,无法将一个庞大的js工程拆分成一个个功能相对独立但相互依赖的小 ...

  2. Docker 与 K8S学习笔记(七)—— 容器的网络

    本节我们来看看Docker网络,我们这里主要讨论单机docker上的网络.当docker安装后,会自动在服务器中创建三种网络:none.host和bridge,接下来我们分别了解下这三种网络: $ s ...

  3. Docker 与 K8S学习笔记(三)—— 镜像的使用

    前面的文章介绍过镜像的三种获取方式: 下载并使用别人创建好的镜像: 在现有镜像上创建新的镜像: 从无到有创建镜像. 本文主要介绍前两种. 一.下载镜像 在Docker Hub上有大量优质镜像可以使用, ...

  4. Docker 与 K8S学习笔记(五)—— 容器的操作(上篇)

    上一篇我们介绍了Dockerfile的基本编写方法,这一节我们来看看Docker容器的常用操作. 一.容器的运行方式 容器有两种运行方式,即daemon形式运行与非daemon形式运行,通俗地讲就是长 ...

  5. Docker 与 K8S学习笔记(九)—— 容器间通信

    容器之间可通过IP.Docker DNS Server或joined三种方式进行通信,今天我们来详细学习一下. 一.IP通信 IP通信很简单,前一篇中已经有所涉及了,只要容器使用相同网络,那么就可以使 ...

  6. Docker 与 K8S学习笔记(二)—— 容器核心知识梳理

    本篇主要对容器相关核心知识进行梳理,通过本篇的学习,我们可以对容器相关的概念有一个全面的了解,这样有利于后面的学习. 一.什么是容器? 容器是一种轻量级.可移植.自包含的软件打包技术,使应用程序可以在 ...

  7. Docker 与 K8S学习笔记(十)—— 容器的端口映射

    我们一般将应用部署在容器里面,而一个服务器上会有许许多多的容器,那么外界该如何访问我们的应用呢?答案是:端口映射. Docker可以将容器对外提供服务的端口映射到host的某个端口上,外网通过此端口访 ...

  8. Docker 与 K8S学习笔记(八)—— 自定义容器网络

    我们在上一篇中介绍了Docker中三种网络,none.host和bridge,除了这三种网络,Docker还允许我们创建自定义网络,当我们要创建自定义网络时,Docker提供了三种网络驱动供我们选择: ...

  9. Docker 与 K8S学习笔记(六)—— 容器的资源限制

    我们在启动Docker容器时,默认情况下容器所使用的资源是没有限制的,这样就会存在部分特别耗资源的容器会占用大量系统资源,从而导致其他容器甚至整个服务器性能降低,为此,Docker提供了一系列参数方便 ...

随机推荐

  1. 用原生CSS编写动态字体

    HTML部分: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ...

  2. 『学了就忘』Linux文件系统管理 — 66、通过图形界面进行LVM分区

    目录 1.选择自定义分区 2.分配boot分区 3.创建LVM物理卷 4.生成卷组 5.创建逻辑卷 6.格式化安装 我们先用新安装Linux系统时的图形化界面,来演示一下LVM逻辑卷如何进行分区. 提 ...

  3. Shell 输出第五行的内容

    目录 Shell 输出第五行的内容 题目 题解-awk 题解-sed Shell 输出第五行的内容 题目 写一个 bash脚本以输出一个文本文件 nowcoder.txt 中第5行的内容. 示例: 假 ...

  4. Shell 分发脚本

    目录 Shell分发脚本 原理 rsync命令分析 特点 基本语法 实现 需求 环境变量 脚本实现 知识点 获得当前路径的目录dirname 获得当前路径的文件名basename shell远程执行命 ...

  5. 学习Java 2021/10/7

    java重写Override 重载Overload 重写是子类对父类的允许访问的方法的实现过程进行重新编写,返回值和形参都不能改变.即外壳不变,核心重写 重写规则: 参数列表与被重写方法的参数列表必须 ...

  6. A Child's History of England.21

    There was one tall Norman Knight who rode before the Norman army on a prancing horse, throwing up hi ...

  7. flink---实时项目--day01--1. openrestry的安装 2. 使用nginx+lua将日志数据写入指定文件中 3. 使用flume将本地磁盘中的日志数据采集到的kafka中去

    1. openrestry的安装 OpenResty = Nginx + Lua,是⼀一个增强的Nginx,可以编写lua脚本实现⾮非常灵活的逻辑 (1)安装开发库依赖 yum install -y ...

  8. zabbix之监控面试

    先用shell脚本把值取出来,然后重启agent,在server端用zabbix-get命令测试一下,看能不能通过userparameter指定的可以将值取出来,如果没问题,在在网页创建模板,加监控项 ...

  9. zabbix之故障自治愈和分层报警

    在agent端修改配置文件 root@ubuntu:~# vim /etc/sudoers zabbix ALL=(ALL) NOPASSWD:ALL#:重启服务root@ubuntu:~# syst ...

  10. spring cloud 通过 ribbon 实现客户端请求的负载均衡(入门级)

    项目结构 环境: idea:2020.1 版 jdk:8 maven:3.6.2 1. 搭建项目 ( 1 )父工程:spring_cloud_demo_parent pom 文件 <?xml v ...