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

时间:2018-04-03 10:43:31

标签: linux docker daemon

我是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容器。

1 个答案:

答案 0 :(得分:1)

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

您可以使用docker inspect <container-id>找到附加到旧postgres容器的卷(可能管道更少并搜索卷)

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

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

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

有关详细信息,请参阅,

docker psdocker volumesdocker rm