我是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容器。
答案 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>
删除旧版本。
有关详细信息,请参阅,