掌控Docker容器生命脉络:docker start、stop、restart、kill 与 wait 命令详解与实战示例

  1. docker start:启动容器

  2. docker stop:优雅地停止容器

  3. docker restart:重启容器

  4. docker kill: 结束容器

  5. docker wait: 等待容器停止,并退出状态

这些命令都直接涉及到容器运行状态的变更和监控,属于容器生命周期管理的核心操作。将它们放在同一部分讨论,有助于读者理解如何控制容器的终止过程以及如何同步地处理容器停止后的后续操作。

1. docker start:启动容器

docker start 命令用于启动一个或多个已停止的 Docker 容器。当需要恢复先前停止的服务、重新启动测试环境、继续进行未完成的任务或在维护后恢复容器运行时,此命令提供了便捷的容器启动机制。以下是使用 docker start 命令启动 hello-go 容器的示例:

假设有一个已停止的名为 hello-go 的容器,您希望将其启动,您可以使用以下命令:

go 复制代码
➜  ~ docker start hello-go

在这条命令中,hello-go 是您要启动的已停止容器的名称。执行命令后,Docker 会重新启动该容器,使其进入运行状态。容器内的主进程将恢复执行,服务或应用程序将再次对外提供服务。

2. docker stop:优雅地停止容器

docker stop 命令用于优雅地停止一个或多个正在运行的 Docker 容器。在需要暂停服务、进行计划内维护、节约资源、或者遵循特定的业务流程时,此命令提供了安全、有序的容器停止机制。以下是使用 docker stop 命令停止 hello-go 容器的示例:

假设您有一个正在运行的名为 hello-go 的容器,您希望将其停止。您可以使用以下命令:

arduino 复制代码
➜  ~ docker stop hello-go

在这条命令中,hello-go 是您要停止的正在运行容器的名称。执行命令后,Docker 会向容器内的主进程发送 SIGTERM 信号,请求其优雅地停止。大多数应用程序在接收到 SIGTERM 信号后,会开始清理资源、保存状态,并在完成这些操作后自行退出。如果容器内的主进程在指定的超时时间内(默认为 10 秒)仍未退出,Docker 将发送 SIGKILL 信号强制终止容器。

3. docker restart:重启容器

docker restart 命令用于重启一个或多个已运行或已停止的 Docker 容器。在需要刷新容器状态、应用配置更改、恢复故障服务或执行定期维护时,此命令提供了快速、便捷的容器重启机制。以下是使用 docker restart 命令重启 hello-go 容器的示例:

无论 hello-go 容器当前是运行中还是已停止状态,您都可以使用以下命令重启它:

go 复制代码
➜  ~ docker restart hello-go

在这条命令中,hello-go 是您要重启的容器的名称。执行命令后,Docker 会执行以下操作:

  1. 停止容器 (如果正在运行):向容器内的主进程发送 SIGTERM 信号,请求其优雅地停止。若容器在指定超时时间内(默认为 10 秒)未退出,Docker 将发送 SIGKILL 信号强制终止容器。

  2. 启动容器:在容器停止后,Docker 会重新启动该容器。容器内的主进程将恢复执行,服务或应用程序将再次对外提供服务。

4. docker kill: 结束容器

docker kill 命令为运维人员提供了即时、强制结束一个或多个运行中容器的能力。在遇到容器无响应、资源占用过高、需紧急下线服务等场景时,此命令能够迅速切断容器的运行状态。由于其非优雅终止的特性,应结合使用 docker stop(优雅停止)和其他管理命令,以实现对容器生命周期的最佳管理。

bash 复制代码
➜  ~ docker kill hello-go

在这条命令中,hello-go 是您要终止的容器名称。执行命令后,Docker 会向容器发送默认的 SIGKILL 信号,强制结束容器内的所有进程,从而停止容器运行。用 docker kill 命令时,容器内的应用程序可能无法完成必要的清理或保存状态操作,可能导致数据丢失或不一致。在涉及关键数据或需要确保服务平滑过渡的场景中,应优先考虑使用 docker stop 命令。

5. docker wait: 等待容器停止,并退出状态

docker wait 命令用于同步阻塞当前命令行,直至指定的容器停止运行,并在容器退出后返回其退出状态码。这一特性使得 docker wait 成为自动化脚本、持续集成/持续部署(CI/CD)流程、多容器协调任务、资源管理以及测试与调试环境中的关键工具,为管理和监控容器生命周期提供了可靠的同步点和状态反馈机制。

bash 复制代码
➜  ~ docker wait hello-go

运行该命令,hello-go会阻塞当前命令行。

打开另一个命令行运行

arduino 复制代码
➜  ~ docker stop hello-gohello-go

回到docker wait hello-go命令行

bash 复制代码
➜  ~ docker wait hello-go2

这时候输出了2。

状态码

  • 0: 正常退出,无错误。

  • 1-127: 非正常退出,通常表示程序运行时遇到错误。

  • 128+n: 由信号 n 导致的退出,如 137 表示接收到 SIGKILL 信号而被强制终止。

本文探讨了五项关键的Docker容器生命周期管理命令:docker startstoprestartkillwait,并通过示例详细展示了每项命令的使用场景、操作方式及预期效果。这些命令共同构成了对容器运行状态进行精细控制的核心工具集,为容器的启动、停止、重启、强制终止以及状态同步提供了强大支持,助力用户高效、安全地管理容器化应用的全生命周期。

忍不住要加个关注!不是我吹,但你会后悔没关注的!

相关推荐
sam-1231 小时前
k8s上部署redis高可用集群
redis·docker·k8s
Fanstay9852 小时前
在Linux中使用Nginx和Docker进行项目部署
linux·nginx·docker
death bell3 小时前
Docker基础概念
运维·docker·容器
天幕繁星5 小时前
docker desktop es windows解决vm.max_map_count [65530] is too low 问题
windows·elasticsearch·docker·docker desktop
想学习java初学者6 小时前
Docker Compose部署Kafka(非Zookeeper)
docker·容器·kafka
尝尝你的优乐美6 小时前
Docker部署Vue项目原来可以那么好用
前端·nginx·docker
迷茫运维路7 小时前
docker搭建Jenkins2.346.3版本及常用工具集成配置(ldap、maven、ansible、npm等)
运维·docker·jenkins·cicd
我叫乐多你养我啊7 小时前
Windows远程连接Docker服务
笔记·docker
mit6.82410 小时前
[Docker#5] 镜像仓库 | 命令 | 实验:搭建Nginx | 创建私有仓库
linux·后端·docker·云原生
牛右刀薛面10 小时前
麒麟V10,arm64,离线安装docker和docker-compose
运维·docker·容器·麒麟·鲲鹏