- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我确实读过这篇文章:https://blog.phusion.nl/2015/01/20/docker-and-the-pid-1-zombie-reaping-problem/
设置一些上下文:文章是关于容器中僵尸的问题,它试图让我们相信这是一个真正的问题。
总的来说,我的心情很复杂。为什么这有关系 ?毕竟,即使主机操作系统中的僵尸能够释放/杀死这个僵尸。我们知道容器中的进程从主机操作系统的角度来看是正常进程(并且通常容器中的进程是具有一些命名空间和 cgroup 的正常进程)。
此外,我们还可以找到为了避免僵尸问题我们应该使用bash -c ...
的信息。为什么 ?也许,更好的选择是使用 --init
?
有人可以解释一下吗?
最佳答案
有关 init 进程为您提供什么的简短但有用的说明,请查看 tini
这是 Docker 在您指定 --init
Using Tini has several benefits:
- It protects you from software that accidentally creates zombie processes, which can (over time!) starve your entire system for PIDs (and make it unusable).
- It ensures that the default signal handlers work for the software you run in your Docker image. For example, with Tini, SIGTERM properly terminates your process even if you didn't explicitly install a signal handler for it.
这两个问题都会影响容器。容器中的进程仍然是宿主机上的进程,所以它占用宿主机上的一个 PID。无论您在容器中运行什么都是 PID 1,这意味着它必须安装一个信号处理程序才能获取该信号。
Bash 恰好包含一个进程收割器,因此在 bash -c
下运行命令可以防止僵尸进程。默认情况下,Bash 不会将信号处理为 PID 1,除非您 trap
它们。
首先要了解的是 init
进程不会神奇地移除僵尸。 (正常)init
旨在当未能等待它们的父进程退出并且僵尸徘徊时收割僵尸。然后 init 进程成为僵尸父进程,它们可以被清理。
接下来,容器是在它们自己的 PID 命名空间中运行的一组进程。这个 cgroup 在容器停止时被清理。在 stop
上移除容器中的任何僵尸。他们没有到达主机init
。
第三是使用容器的不同方式。大多数运行一个主进程,没有别的。如果产生了另一个进程,它通常是该主进程的子进程。所以直到父级退出,僵尸才会存在。然后看第 2 点(僵尸将在容器导出处被清除)。
在容器中运行 Node.js、Go 或 Java 应用服务器往往不会严重依赖进程的 fork 或派生。
运行像 Jenkins worker 这样的东西,它产生大量涉及 shell 的临时作业可能会导致更糟糕的情况,但它是短暂的,因此会定期退出并清理
运行一个 Jenkins master,它也会产生作业。容器可能会闲置很长时间并留下许多僵尸进程,这是一种在没有僵尸收割者的情况下可能会出现问题的工作负载。
init 进程可以提供的另一个作用是安装信号处理程序,以便可以将主机发送的信号传递到容器进程。 PID 1 有点特殊,因为它需要进程监听信号才能接收。
如果您可以在您的 PID 1 进程中安装 SIGINT
和 SIGTERM
信号处理程序,那么 init 进程不会在此处添加太多内容。
多个进程应该在一个 init 进程下运行。当 Docker 启动时,init 管理它们应该如何启动。容器真正“运行”它所代表的服务需要什么。当容器停止时,应该如何将其传递给每个进程。不过,您可能想要一个更传统的初始化系统,s6通过 s6-overlay为多进程管理提供了许多有用的容器特性。
尤其是当进程是children 的children 或超越的时候。 CI worker (如 Jenkins)示例是第一个想到 Java 生成命令或生成其他命令的 shell 的示例。
sleep
就是一个简单的例子。 docker run busybox sleep 60
不能被 ctrl-c 中断或停止,它将在默认的 10 秒 docker stop
超时后被杀死。 docker run --init busybox sleep 60
按预期工作。
tini
的开销非常小,并且被广泛使用,那么为什么大部分时间不使用 --init
呢?
更多详情见this github comment哪个回答了“为什么?”来自 tini 创作者的问题。
关于Docker - 初始化,僵尸 - 为什么重要?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49162358/
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
我正在尝试修改网站的布局,但有时网站会使用 !important,有没有办法覆盖它?我似乎无法弄清楚如何在页面的 css 文件之后加载 css 内容脚本。 最佳答案 !important CSS 规则
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 9 年前。 我写了一些 html,并在第三方网站中注入(inject)了一些 css 样
好的,我在这里安装了一个 wordpress 主题(www.sullivansuccesscoaching.com/home ...我们需要/home,因为仍然有一个 index.html 隐藏了 w
我已经为我的 Wordpress 模板创建了一个覆盖原始 CSS 的自定义样式表。但是,在我的日历页面上,原始 CSS 具有使用 !important 声明设置的每个表格单元格的高度: td {hei
这个问题在这里已经有了答案: How to document deconstructed parameters with JsDoc (1 个回答) 关闭 5 年前。 我正在努力寻找对文档 ES6
我的网站使用 bootstrap 4 和我制作的 css 文件。 在这个 css 文件的底部,我放置了一些媒体查询: @media (max-width: 575px) { .address .c
可以将 background-position X 设置为 0 带有标志 !important 和背景位置 Y 不带 !important? 例如: background-position-x: 0
我只想在焦点状态下去掉下拉列表中的轮廓。看这张图 我尝试使用 !important 覆盖 Bootstrap ,但根本不起作用。只是检查开发工具,突然看到这个。 Bootstrap 也使用 !impo
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 1 年前。
发生了什么事?:我的 jQuery Accordion 的动画坏了。在关闭上一个选项卡之前短时间单击下一个选项卡后,它会显示之前打开的选项卡。动画也不滑动。 CSS:来自this answer /*
如何使用 javascript 或 CSS 覆盖样式“color: red”?我想让它成为“2px”而不是“1px”边框。 Lorem... 我无法向“div”添加类、id。这不
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 5 年前。
滚动有问题不想显示其内容,如果我这样做 #callCenter { position: fixed; z-index: 2411 !important; display: bl
序言 1、MySQL表操作(创建表,查询表结构,更改表字段等), 2、MySQL的数据类型(CHAR、VARCHAR、BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大
如何将!important添加到客户端包GWT中的gwt-image: 我有这个: @sprite .superButton{ gwt-image : 'superButton'; backg
请帮助我..我想验证表单并使用 ajax 发送。 验证没有 ''onsubmit="return validateForm(this);"'' 工作。 但是当表单正确时,它的发送表单(页面刷新..)请
我是一名优秀的程序员,十分优秀!