05_container/5.3_stop.md
本节将介绍如何终止一个运行中的容器,以及几种不同的终止方式及其区别。
终止容器有三种方式:
| 方式 | 命令 | 说明 |
|---|---|---|
| 优雅停止 | docker stop | 先发 SIGTERM,超时后发 SIGKILL |
| 强制停止 | docker kill | 直接发 SIGKILL |
| 自动终止 | - | 容器主进程退出时自动停止 |
$ docker stop 容器名或ID
flowchart TD
cmd["docker stop mycontainer"] --> A["1. 发送 SIGTERM 信号给容器主进程 (PID 1)"]
A --> B["2. 等待容器优雅退出 (默认 10 秒)"]
B --> C["3. 如果超时仍未退出,发送 SIGKILL 强制终止"]
## 等待 30 秒后强制终止
$ docker stop -t 30 mycontainer
## 立即发送 SIGKILL(相当于 docker kill)
$ docker stop -t 0 mycontainer
## 停止多个指定容器
$ docker stop container1 container2 container3
## 停止所有运行中的容器
$ docker stop $(docker ps -q)
$ docker kill 容器名或ID
| 命令 | 信号 | 使用场景 |
|---|---|---|
docker stop | SIGTERM → SIGKILL | 正常停止,让应用优雅退出 |
docker kill | SIGKILL | 应用无响应,强制终止 |
## 发送 SIGHUP(让进程重新加载配置)
$ docker kill -s HUP mycontainer
## 发送 SIGTERM
$ docker kill -s TERM mycontainer
容器的生命周期与主进程绑定。主进程退出时,容器自动停止:
## 主进程是交互式 bash
$ docker run -it ubuntu bash
root@abc123:/# exit # 退出 bash → 容器停止
## 主进程执行完毕
$ docker run ubuntu echo "Hello" # echo 执行完 → 容器停止
$ docker ps -a
CONTAINER ID IMAGE COMMAND STATUS NAMES
ba267838cc1b ubuntu "/bin/bash" Exited (0) 2 minutes ago myubuntu
c5d3a5e8f7b2 nginx "nginx" Up 5 minutes mynginx
STATUS 字段说明:
| 状态 | 说明 |
|---|---|
Up X minutes | 运行中 |
Exited (0) | 正常退出 (退出码 0) |
Exited (1) | 异常退出 (非零退出码) |
Exited (137) | 被 SIGKILL 终止 (128 + 9) |
Exited (143) | 被 SIGTERM 终止 (128 + 15) |
$ docker start 容器名或ID
## 启动并附加终端
$ docker start -ai 容器名
## 先停止再启动
$ docker restart 容器名
## 自定义停止超时
$ docker restart -t 30 容器名
stateDiagram-v2
direction TB
[*] --> Created : docker create
Created --> Running : docker start
Running --> Stopped : docker stop
Running --> Paused : docker pause
Paused --> Running : docker unpause
Created --> Deleted : docker rm
Stopped --> Deleted : docker rm
Paused --> Deleted : docker rm
Deleted --> [*]
$ docker stop $(docker ps -q)
$ docker container prune
$ docker stop $(docker ps -q) && docker container prune -f
原因:应用没有正确处理 SIGTERM 信号,需要等待超时后强制终止。
解决方案:
docker stop -t 0 立即终止STOPSIGNAL 配置确保容器主进程正确处理信号:
## Dockerfile 示例
FROM node:22-alpine
...
## 使用 exec 形式确保信号能传递给 node 进程
CMD ["node", "server.js"]
版本说明:示例使用
node:22-alpine,这是一个精简的 Node.js 22 版本镜像。可根据需求替换为其他版本(如node:24-alpine、node:latest)。
## 强制终止
$ docker kill 容器名
## 如果仍无法停止,检查系统资源
$ docker inspect 容器名