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

简介: 上一篇我们学习了容器的启动和常用的进入容器的方式,今天我们来看看如何控制容器起停以及容器删除操作。 一、stop、kill、start和restart stop、kill命令都可以停止运行的容器,二者不同之处在于,stop是先给容器中的进程发送SIGTERM信号,一段时间后在发送SIGKILL信号,

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


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


一、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容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
8月前
|
存储 Kubernetes 网络安全
关于阿里云 Kubernetes 容器服务(ACK)添加镜像仓库的快速说明
本文介绍了在中国大陆地区因网络限制无法正常拉取 Docker 镜像的解决方案。作者所在的阿里云 Kubernetes 集群使用的是较旧版本的 containerd(1.2x),且无法直接通过 SSH 修改节点配置,因此采用了一种无需更改 Kubernetes 配置文件的方法。通过为 `docker.io` 添加 containerd 的镜像源,并使用脚本自动修改 containerd 配置文件中的路径错误(将错误的 `cert.d` 改为 `certs.d`),最终实现了通过多个镜像站点拉取镜像。作者还提供了一个可重复运行的脚本,用于动态配置镜像源。虽然该方案能缓解镜像拉取问题,
890 3
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
针对本地存储和 PVC 这两种容器存储使用方式,我们对 ACK 的容器存储监控功能进行了全新升级。此次更新完善了对集群中不同存储类型的监控能力,不仅对之前已有的监控大盘进行了优化,还针对不同的云存储类型,上线了全新的监控大盘,确保用户能够更好地理解和管理容器业务应用的存储资源。
790 278
|
Kubernetes 调度 异构计算
生产环境 K8S + Deepseek 实现大模型部署 和 容器调度(图解+史上最全)
生产环境 K8S + Deepseek 实现大模型部署 和 容器调度(图解+史上最全)
生产环境 K8S + Deepseek 实现大模型部署 和 容器调度(图解+史上最全)
|
Kubernetes Docker 容器
Kubernetes与Docker参数对照:理解Pod中的command、args与Dockerfile中的CMD、ENTRYPOINT。
需要明确的是,理解这些都需要对Docker和Kubernetes有一定深度的理解,才能把握二者的区别和联系。虽然它们都是容器技术的二个重要组成部分,但各有其特性和适用场景,理解它们的本质和工作方式,才能更好的使用这些工具,将各自的优点整合到生产环境中,实现软件的快速开发和部署。
552 25
|
数据采集 消息中间件 Kubernetes
容器化爬虫部署:基于K8s的任务调度与自动扩缩容设计
随着业务复杂度提升,传统定时任务和手工扩缩容难以满足高并发与实时性需求。本文对比两种基于 Kubernetes 的爬虫调度与扩缩容方案:CronJob+HPA 和 KEDA。从调度灵活性、扩缩容粒度、实现难度等维度分析,并提供 YAML+Python 示例。方案 A(CronJob+HPA)适合固定定时任务,配置简单;方案 B(KEDA)支持事件驱动,适合高并发与异步触发场景。根据实际需求可混合使用,优化资源利用与效率。
477 4
|
存储 运维 Kubernetes
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案
飞轮科技推出了 Doris 的 Kubernetes Operator 开源项目(简称:Doris Operator),并捐赠给 Apache 基金会。该工具集成了原生 Kubernetes 资源的复杂管理能力,并融合了 Doris 组件间的分布式协同、用户集群形态的按需定制等经验,为用户提供了一个更简洁、高效、易用的容器化部署方案。
1001 16
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
434 0
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
335 1
|
弹性计算 人工智能 资源调度
DeepSeek大解读系列公开课上新!阿里云专家主讲云上智能算力、Kubernetes容器服务、DeepSeek私有化部署
智猩猩「DeepSeek大解读」系列公开课第三期即将开讲,聚焦阿里云弹性计算助力大模型训练与部署。三位专家将分别讲解智能算力支撑、Kubernetes容器服务在AI场景的应用实践、以及DeepSeek一键部署和多渠道应用集成,分享云计算如何赋能大模型发展。欲观看直播,可关注【智猩猩GenAI视频号】预约。 (239字符)
|
监控 Kubernetes Cloud Native
基于阿里云容器服务Kubernetes版(ACK)的微服务架构设计与实践
本文介绍了如何基于阿里云容器服务Kubernetes版(ACK)设计和实现微服务架构。首先概述了微服务架构的优势与挑战,如模块化、可扩展性及技术多样性。接着详细描述了ACK的核心功能,包括集群管理、应用管理、网络与安全、监控与日志等。在设计基于ACK的微服务架构时,需考虑服务拆分、通信、发现与负载均衡、配置管理、监控与日志以及CI/CD等方面。通过一个电商应用案例,展示了用户服务、商品服务、订单服务和支付服务的具体部署步骤。最后总结了ACK为微服务架构提供的强大支持,帮助应对各种挑战,构建高效可靠的云原生应用。

相关产品

  • 容器服务Kubernetes版