Docker无法stop或者rm指定容器

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掉

bash 复制代码
lsof | grep "f8ccd87c97147abfdf8d3e11ed20d91f2a719dc249ce4bc37a32923689e0787c"

结果查出一大堆数据,不可能一个一个kill吧

于是使用 docker inspect 和 awk 来获取并杀死容器主进程PID

bash 复制代码
# 获取容器主进程的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'脚本是我自己的,你们用你们自己的)

bash 复制代码
docker-compose -f /data/compose/nginx-arm64.yml up -d

验证了一下重启命令,发现没问题了。

相关推荐
DianSan_ERP5 小时前
如何通过抖店订单接口实现订单状态管理与履约自动化?
运维·自动化
亚空间仓鼠5 小时前
Docker容器化高可用架构部署方案(六)
docker·容器·架构
b***25115 小时前
18650电池点焊机:电阻焊技术如何决定电池组的成败|深圳比斯特自动化
运维·自动化
原来是猿5 小时前
网络计算器:理解序列化与反序列化(中)
linux·运维·服务器·网络·tcp/ip
前端老曹5 小时前
Docker 从入门到放弃:完整指南
运维·docker·容器
AOwhisky6 小时前
虚拟化技术学习笔记
linux·运维·笔记·学习·虚拟化技术
咖啡里的茶i7 小时前
在Docker环境中安装Hadoop cluster 实验报告一
hadoop·docker·容器
汪汪大队u7 小时前
续:从 Docker Compose 到 Kubernetes(2)—— 服务优化与排错
网络·后端·物联网·struts·容器
rabbit_pro7 小时前
Docker compose部署Ollama使用模型
linux·运维·docker
ILL11IIL8 小时前
k8s的pod管理及优化
云原生·容器·kubernetes