preStop 钩子和终止GracePeriodSeconds 之间的关系

2024-01-17

基本上我想做的是研究 Pod 生命周期,并检查我们是否可以在 Pod 终止之前进行一些清理/备份,例如复制日志。

我需要的 : 在终止之前将日志/堆转储从容器复制到 hostPath/S3

我尝试过的:

我使用了带有 bash 命令的 preStop 钩子来回显一条消息(只是为了看看它是否有效!!)。使用带有延迟的终止GracePeriodSeconds 来预停止并切换它们以查看进程是否有效。前任。保持终止GracePeriodSeconds:30秒(默认)并将preStop命令设置为休眠50秒,并且不应生成消息,因为容器将在那时终止。这按预期工作。

我的问题:

  • preStop 钩子允许(推荐)什么样的进程?因为复制 15 GB 或更多的日志/堆转储将花费大量时间。该时间将用于定义终止GracePeriodSeconds
  • 当 preStop 花费的时间超过设定的宽限期时会发生什么? (如果日志很大,比如 10 场)
  • 如果我没有任何钩子但仍设置终止GracePeriodSeconds 会发生什么?容器会一直保持到宽限期吗?

我发现这篇文章与此密切相关,但无法跟进https://github.com/kubernetes/kubernetes/issues/24695 https://github.com/kubernetes/kubernetes/issues/24695

所有投入表示赞赏!


preStop 钩子允许(推荐)什么样的进程?因为复制 15 GB 或更多的日志/堆转储将花费大量时间。该时间将用于定义终止GracePeriodSeconds

这里什么都可以,这更多的是一种意见以及你希望你的豆荚如何徘徊。另一种选择是让您的 Pod 终止并将数据存储在某个位置(即 AWS S3、EBS),其中数据将在 Pod 生命周期结束后持续存在,然后使用类似的方法Job https://kubernetes.io/docs/tasks/job/清理数据等

当 preStop 花费的时间超过设定的宽限期时会发生什么? (如果日志很大,比如 10 场)

您的 preStop 将无法完成,这可能意味着数据不完整或数据损坏。

如果我没有任何钩子但仍设置终止GracePeriodSeconds 会发生什么?容器会一直保持到宽限期吗?

这解释了顺序:

  • SIGTERM 信号被发送到每个容器中的主进程,并且“宽限期”倒计时开始。
  • 如果容器没有在宽限期内终止,则会发送 SIGKILL 信号并终止容器。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

preStop 钩子和终止GracePeriodSeconds 之间的关系 的相关文章

随机推荐

  • 如何在 Visual Studio 中为自定义配置文件添加配置转换?

    我正在从事的项目涉及从配置文件读取大量服务端点 url 由于列表相当大 我决定将它们保存在自定义配置文件中 以保持我的 web config 干净且小 我将自定义部分添加到我的网站中 如下所示
  • Active Directory LDAP 查询结果始终缺少已知存在的属性

    这是我目前遇到的一个问题 用户个人资料有一个属性 EmployeeID 当使用以下命令查看该用户时会出现该属性广告浏览器 http technet microsoft com en us sysinternals bb963907 aspx
  • HTML5 离线应用程序缓存更新未在 Firefox 中显示

    我的文档根目录中有一个index php 文件 它产生以此开头的输出 manifest appcache 告诉浏览器缓存它以供离线使用 再次 相关部分 CACHE MANIFEST version 8 25 2011 CACHE inter
  • 无法在 call.enqueue 的 for 循环之外获取 ArrayList

    我想从 Retrofit 中的 call enqueue 方法中获取 ArrayList 数据 如何访问 call enqueue 方法之外的列表 一切正常 当打印列表大小时 我得到了我想要的值 唯一的问题是我无法从 call enqueu
  • 在 Swift 中设置带有边距的 UITableViewCell 框架

    我正在尝试制作一个具有左右边距 插图的 UITableViewCell 我过去曾使用 Objective C 使用以下代码完成此操作 void setFrame CGRect frame frame origin x 25 frame si
  • 使用 C++ 11 进行重构

    鉴于 c 提供的新工具集 许多程序员以代码简化 表现力 效率为目标 浏览旧代码并进行调整 有些毫无意义 有些成功 以实现他们的目标 虽然尽量不要在此类工作上浪费太多时间 而只是进行非侵入性且独立的更改 但最佳实践是什么 让我划掉显而易见的部
  • instanceof 检测接口时产生不一致的结果?

    有什么棘手的事情我应该知道吗instanceof 我通过一些方法传递对象列表 并使用以下方法测试这些对象是否实现特定接口instanceof 在某些情况下 instanceof正确地将对象识别为实现接口 但在其他情况下则不然 它似乎在不同地
  • 将日期/时间解析为本地时区

    我正在尝试从服务器端绑定视图持有者解析日期 时间 json 我试图解析的日期字符串是这样的 2018 06 25T08 06 52Z 这是我正在使用的代码 从另一个堆栈溢出线程获取它 try SimpleDateFormat df new
  • Visual Studio 2010 中的 Visual C++ 中的 LNK 2005

    我正在尝试在 MS VS 2010 中编译使用 Visual C 2005 和 MFC 编写的 C 程序 遗憾的是 我在编译过程中遇到以下错误 Error 2 error LNK2005 public virtual thiscall CM
  • 在开发服务器上测试/预览 Github 分支

    我刚刚从 svn 迁移到 github 我和我的团队运行本地测试 并在中央开发服务器上提交更改和测试 每当我们将更改推送到存储库时 我希望自动将对存储库任何分支的更改拉入开发服务器上的文件夹中 这将使我和我的团队能够使用我们的中央开发服务器
  • 如何查询在 Parse 中设置为指向其他表的指针的列的值

    我在用Parse http parse com对于我的应用程序 我想查询一个表 其中的列设置为指向其他表的指针 这是查询 ParseQuery query new ParseQuery CategoryAttribute query whe
  • 将十六进制字符串转换为文本的 NSString?

    我需要将十六进制值的 NSString 转换为文本 ASCII 的 NSString 例如 我需要类似的东西 68 65 78 61 64 65 63 69 6d 61 6c to be hexadecimal 我查看并调整了代码这个线程
  • NHibernate - 查询中的错误列

    我遇到了 NHibernate 的间歇性问题 它生成一个实体的查询 但将其中一个列替换为来自完全不同 且不相关 实体的列 它只替换单个列 并且通常通过重新启动应用程序来解决 尽管有时需要几次尝试 ASP NET 应用程序 NET 4 0 S
  • ASP.NET Web 应用程序文件路径(在 Azure 上发布)

    问题 对于一个学校项目 我创建了一个 REST Web 服务 该服务与一个数据库链接 该数据库从 Excel 文件获取数据 在我的 Migration Configuration cs 类中 我读取了 excel 文件并将它们放入数据库中
  • 如何解决实体映射中的 Grails 错误重复列?在现有的 Postgresql 数据库上

    您好 我在 Grails 中有以下域 class Customer static mapping table customer version is set to false because this isn t available by
  • config.json - 在 ASP.NET vNext 中添加数据库连接字符串

    我正在学习 ASP NET vNext 我需要在 config json 文件中存储两个连接字符串 我如何存储这些 我可以这样做吗 配置 json connectionStrings connection 1 server connecti
  • 在 Python Tkinter 窗口中显示 Google Map API

    大家好 我正在用 Python 开发 Google Map API 我正在使用可以在这里找到的源代码website http pymaps googlecode com svn trunk pymaps py 此代码编译后会生成一个 htm
  • Linux 中有挂起/恢复信号吗?

    我的应用程序需要对休眠模式做出反应 以便它可以在暂停时执行一些操作 在恢复时执行其他操作 我找到了一些特定于分布式的方法来实现它 Upower DBus 但没有找到任何通用的方法 有办法做到吗 Thanks 一个简单的解决方案是使用自管 打
  • 为什么从 Go 1.17 开始 go.mod 中有两个“require”块?

    我创建了一个小型 go 应用程序 几天前我已经从 go 1 15 升级到 1 17 并且我还升级了软件包go get u 更改后 我的 go mod 文件中有 2 个 require 块 为什么 这是什么意思 没问题还是有什么东西坏了 应用
  • preStop 钩子和终止GracePeriodSeconds 之间的关系

    基本上我想做的是研究 Pod 生命周期 并检查我们是否可以在 Pod 终止之前进行一些清理 备份 例如复制日志 我需要的 在终止之前将日志 堆转储从容器复制到 hostPath S3 我尝试过的 我使用了带有 bash 命令的 preSto