Docker无法stop或者rm指定容器
今日准备重启一下docker 容器部署的 Nginx 时,使用的命令是
docker exec -it ir-nginx nginx -s reload
结果发现无法重启报错
然后想着关闭再启动,结果发现
docker restart 、docker stop 、docker kill 、docker exec
都不行
于是用systemctl stop docker再 systemctl start docker
虽然命令可以执行成功,但是Nginx那个容器还是不能关闭、重启
执行 docker restart
报错记录的为
OCI runtime exec failed: exec failed: json: cannot unmarshal number into Go struct field CompatState.init_process_start of type string: unknown
于是想着再复制一个yml脚本(弄一个新的docker),改了一下里面的信息
再执行 docker-compose -f /data/compose/nginx-arm64-v2.yml up -d
报错记录的为
Error response from daemon: Cannot restart container f8ccd87c9714: Cannot kill container f8ccd87c97147abfdf8d3e11ed20d91f2a719dc249ce4bc37a32923689e0787c: unknown error after kill: runc did not terminate sucessfully: json: cannot unmarshal number into Go struct field CompatState.init_process_start of type string
里面有个 f8ccd87c97147abfdf8d3e11ed20d91f2a719dc249ce4bc37a32923689e0787c
的id
(后续:往后就直接执行原来的yml,关键是要把这个特别长的id拿到)
于是想查找与容器ID相关的文件或套接字,把它kill掉
lsof | grep "f8ccd87c97147abfdf8d3e11ed20d91f2a719dc249ce4bc37a32923689e0787c"
结果查出一大堆数据,不可能一个一个kill吧
于是使用 docker inspect 和 awk 来获取并杀死容器主进程PID
# 获取容器主进程的PID
PID=$(docker inspect -f '{{.State.Pid}}' f8ccd87c97147abfdf8d3e11ed20d91f2a719dc249ce4bc37a32923689e0787c) # 杀死该PID(请谨慎使用)
kill $PID
该操作可以直接在控制台执行
在同一个 shell 会话中连续执行这两个命令时,第二个命令能够“知道”它的 PID 来自于上一条命令的记录,因为第一个命令的输出被
临时存储(关闭终端窗口或退出 shell 会话时,变量就会消失)
在了 PID 变量中,并且这个变量在后续的命令中是可以被引用的。
然后发现通过
docker ps (查看"正在运行"的容器) ,看不到那个容器了
通过 docker ps -a 可以看到,表示已经被关闭了
于是再把这个容器给删除了
docker rm -f ir-nginx
最后再执行(这个yml‘脚本是我自己的,你们用你们自己的)
docker-compose -f /data/compose/nginx-arm64.yml up -d
验证了一下重启命令,发现没问题了。