- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题旨在验证并可能纠正我对 Docker 容器可靠性的看法。我阅读了 Docker 文档和几篇关于 Dockerfile 中的 VOLUME
和 --v
的文章,作为在运行容器时将数据持久保存在 Docker 容器外的方法的参数。无论是在数据容器中还是在主机系统上。为了使设置的复杂性保持简单,我宁愿不到处复制/保存/存储数据,而是将其保存在 Docker 容器本身中。
我通过几个案例发现了 Docker 容器的行为。我想知道我是否错过了容器可能 100% 无意丢失的场景,即不执行 $ docker rm -f mycontainer
用于暂停、停止和终止容器的 docker 命令-> 可通过 $ docker restart mycontainer
或 $ docker run mycontainer
主机系统重启-> docker 容器以 0 或 255 退出
主机系统意外断电-> 会发生什么?
应用异常-> docker 容器以 -1 退出
更新或重启 docker(正如 Greg 所指出的)-> 预期行为:就像系统重启时一样 (?)
在所有这些情况下,docker 容器最终仍然存在。那么是否有任何其他情况会导致 docker 容器丢失,例如 $ docker rm -f mycontainer
?
背景是,我阅读了很多有关 Postgres 主机系统上挂载卷和外部数据存储的内容,但我想尽可能避免将数据存储在主机系统上的容器之外。另一方面,我不想一觉醒来发现所有数据都丢失了。 (我确实执行常规的 SQL 转储,但我不想每 5 分钟执行一次)。如果 docker 容器本身对于持久数据不可靠,我不明白为什么我应该创建第二个容器来保存第一个容器的数据并通过添加一个新容器来增加我的系统的复杂性但没有获得任何东西可靠性。
编辑:Docker userguide on Volumes中有两点它没有明确解释预期的行为,因此让我质疑这些概念是否提供了额外的可靠性:
更新数据卷时不会包含对数据卷的更改图片-> 这是否意味着他们迷路了或卷的内容不会更改?
卷一直存在,直到没有容器使用它们-> “使用”的定义是什么?只要容器不被停止、杀死、删除?这是否意味着 Docker 在主机系统上创建的卷将被删除?还是卷只是指 Docker 内部目录与主机系统目录之间的虚拟桥?
最佳答案
如果你把你所有的数据都存储在容器里,当你需要更新镜像的时候你打算怎么办?镜像的更新通常通过更改 Dockerfile 和重建镜像来完成。如果我的数据与我的容器分开,我可以启动一个新版本的图像,使用 --volumes-from
或 -v
挂载数据并杀死旧的容器。在您的情况下,您必须保持容器运行并尝试使用 puppet 之类的东西进行修补。
此外,我不确定您认为自己节省了什么。如果您运行官方 postgres 图像,它将在 Dockerfile 中声明卷。无论您是否使用 -v
运行容器,这些卷都作为主机系统上的普通目录存在。即使您的 Dockerfile 没有卷,显然 UFS 无论如何都存储在您的主机上。
一般来说,您应该将容器视为临时的和无状态的。虽然您不必这样做,但您会发现大多数工具和支持服务都是围绕这个习语设计的。
关于您的场景,您缺少一些:
为了清楚起见,docker start
将重新启动已停止或退出的容器,docker unpause
将取消暂停暂停的容器。
关于postgresql - Docker容器的可靠性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28345352/
我正在使用以下dockerfile: FROM ubuntu:14.04 MAINTAINER xxx xxx # SSH RUN apt-get update && apt-get install
我运行了docker-compose build celery,(经过数小时的尝试,我的连接不良)成功了。 app Dockerfile的前80%是相同的,但不会重复使用缓存。从我可以浏览的内容来看,
我可以使用以下命令成功创建 Docker 注册表 v2 服务:docker service create 然后我使用 docker Push 将一些图像推送到该服务。 当我通过 curl localh
我正在尝试使用 gitlab 构建 CI,我从 docker 的 docker 镜像开始,我的前端存储库没有任何问题,但现在使用相同的 gitlab-ci 配置文件,我有此守护程序错误。 这是构建的输
用例: 我们在 Jenkins 中有几个“发布作业”build 和 push 应用程序的 Docker 镜像到 docker registry,更新各种文件中的项目版本,最后将发布标签推送到相应的 G
当我尝试构建我的 docker 文件时,docker 返回以下错误: [+] Building 0.0s (1/2)
docker-in-docker 的作者在此博客中建议不要将此图像用于 CI 目的: jpetazzo/Using Docker-in-Docker for your CI or testing en
我创建了一个 Dockerfile 来在 Docker 中运行 Docker: FROM ubuntu:16.04 RUN apt-get update && \ apt-get in
我尝试为 Docker 镜像定位一个特定标签。我怎样才能在命令行上做到这一点?我想避免下载所有图像,然后删除不需要的图像。 在 Ubuntu 官方版本中,https://registry.hub.do
我正在尝试在docker中运行docker。唯一的目的是实验性的,我绝不尝试实现任何功能,我只想检查docker从另一个docker运行时的性能。 我通过Mac上的boot2docker启动docke
docker-compose.yml version: "3" services: daggr: image: "docker.pvt.com/test/daggr:stable"
我有一个非常具体的开发环境用例。在一些代码中,我启动了一个容器来抓取页面并检索在容器中运行的服务(Gitlab)的 token 。 现在,我希望 Dockerize 运行它的代码。具体来说,类似: o
之前已经问过这个问题,但我不确定当时是否可以使用docker-compose文件完成docker堆栈部署。 由于最新版本支持使用compose将服务部署到堆栈,因此,我无法理解dab文件的值。 我检查
我在一次采访中被问到这个问题,但无法回答。也没有找到任何相关信息。 最佳答案 正如 Docker 文档中所述,Docker 注册表是: [...] a hosted service containin
有没有一种方法可以将具有给定扩展名的所有文件复制到Docker中的主机?就像是 docker cp container_name:path/to/file/in/docker/*.png path/o
我的日志驱动程序设置为journald。使用日志记录驱动程序时,daemon.json文件中的日志级别配置会影响日志吗?使用docker logs 时仅会影响容器日志? 例如,docker和journ
我最近开始使用Docker + Celery。我还共享了full sample codes for this example on github,以下是其中的一些代码段,以帮助解释我的观点。 就上下文
运行docker build .命令后,尝试提交构建的镜像,但收到以下错误 Step 12 : CMD activator run ---> Using cache ---> efc82ff1ca
我们有docker-compose.yml,其中包含Kafka,zookeeper和schema registry的配置 当我们启动docker compose时,出现以下错误 docker-comp
我是Docker的新手。是否可以在Docker Hub外部建立Docker基本镜像存储库?假设将它们存储在您的云中,而不是拥有DH帐户?谢谢。 最佳答案 您可以根据需要托管自己的注册表。可以在Depl
我是一名优秀的程序员,十分优秀!