无法重新启动 docker 容器:OCI 运行时创建失败:存在 ID 的容器

Can't restart docker container: OCI runtime create failed: container with id exist

我是 Docker 的新人,在提问之前我尝试在 google 中找到解决方案 - 没有结果。

我决定通过实际用例学习 docker - 在我的 VM 实例中创建 PostgreSQL 容器用于开发环境。 我一直在度假,几天没有检查我的服务器。后来我尝试连接到我的数据库,但无法连接 - 我所有的活动容器都已退出,代码为 128。 我试图用数据库重新启动容器 - docker start django-postgres 并收到错误消息 - Error response from daemon: OCI runtime create failed: container with id exists: 5c11e724bf52dd1cb6fd10ebda40710385e412981eb269c30071ecc8aac9e805: unknown Error: failed to start containers: django-postgres

我怀疑我的系统 docker 中的某个地方保留了我的容器的一些元数据,这些元数据在容器因代码 128 而宕机后没有被删除,但我对 unix 的了解不足以确定它可以在哪里。另外,我担心丢失与容器连接的数据库数据。

一些技术信息: docker version:

Version: 18.03.0-ce API version: 1.37 Go version: go1.9.4 Git commit: 0520e24 Built: Wed Mar 21 23:10:01 2018 OS/Arch: linux/amd64 Experimental: false Orchestrator: swarm

docker info

Containers: 9
 Running: 2
 Paused: 0
 Stopped: 7
Images: 5
Server Version: 18.03.0-ce
Storage Driver: overlay2
 Backing Filesystem: extfs
 Supports d_type: true
 Native Overlay Diff: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins:
 Volume: local
 Network: bridge host macvlan null overlay
 Log: awslogs fluentd gcplogs gelf journald json-file logentries splunk syslog
Swarm: inactive
Runtimes: runc
Default Runtime: runc
Init Binary: docker-init
containerd version: cfd04396dc68220d1cecbe686a6cc3aa5ce3667c
runc version: 4fc53a81fb7c994640722ac585fa9ca548971871
init version: 949e6fa
Security Options:
 apparmor
 seccomp
  Profile: default
Kernel Version: 4.4.0-116-generic
Operating System: Ubuntu 16.04.4 LTS
OSType: linux
Architecture: x86_64
CPUs: 1
Total Memory: 488.3MiB
ID: NDUH:OH24:4M4L:TR5O:TOIH:ARV4:LNRP:6QNE:WEYW:TMXR:7KNK:ZPDD
Docker Root Dir: /var/lib/docker
Debug Mode (client): false
Debug Mode (server): false
Registry: https://index.docker.io/v1/
Labels:
Experimental: false
Insecure Registries:
 127.0.0.0/8
Live Restore Enabled: false

WARNING: No swap limit support

有没有人可以帮助我理解我的问题以及如何在不丢失数据的情况下解决它?

N.B. 第二个用代码 128 退出的容器是 OpenVPN。我也无法重新启动它,但错误有所不同 - cgroups: cannot found cgroup mount destination: unknown 我找到了解决方案 here (github):

Temp fix is
sudo mkdir /sys/fs/cgroup/systemd
sudo mount -t cgroup -o none,name=systemd cgroup /sys/fs/cgroup/systemd

此修复对 Postgres 容器没有帮助。

可以使用 docker ps -a 列出所有 运行 和停止的容器。 -a or --all 显示所有容器(默认仅显示 运行)。

您可以使用 docker inspect <container-id> 找到附加到您的旧 postgres 容器的卷(也许通过管道连接到 less 并搜索卷)

如果要恢复数据,可以将其附加到新的 postgres 容器并进行恢复。 (如果是根卷更改目标为/

docker run --name new-postgres \
--mount source=myoldvol,target=/var/lib/postgresql/data -d postgres

然后您可以使用 docker rm <container-id> 删除旧的。

更多信息请看,

docker ps, docker volumes, docker rm