Sidekiq MemoryKiller

Sidekiq MemoryKiller

GitLab Rails 应用程序代码遭受内存泄漏. 对于 Web 请求,可以使用来解决此问题,如果超过内存限制,它将重新启动 Puma worker 进程. Sidekiq MemoryKiller 对 GitLab 用来处理后台作业的 Sidekiq 进程采用相同的方法.

与 puma-worker-killer(自 GitLab 13.0 起默认对所有 GitLab 安装启用)不同,Sidekiq MemoryKiller 默认仅对 Omnibus 软件包启用. 这样做的原因是,MemoryKiller 依赖于 runit 在内存引起的关闭之后重新启动 Sidekiq,并且从源头安装 GitLab 并不全部使用 runit 或等效版本.

使用默认设置,MemoryKiller 将使 Sidekiq 重新启动的频率不超过每 15 分钟一次,并且重新启动会为传入的后台作业造成大约一分钟的延迟.

一些后台作业依赖于长时间运行的外部流程. 为确保在重启 Sidekiq 时将它们彻底终止,每个 Sidekiq 进程应以进程组负责人的身份运行(例如,使用chpst -P ). 如果使用 Omnibus 或安装了runitbin/background_jobs脚本, runit为您处理.

使用环境变量控制 MemoryKiller.

  • 传统模式下,MemoryKiller 在每个作业后检查 Sidekiq 进程 RSS.

    守护程序模式下,MemoryKiller 每 3 秒检查一次 Sidekiq 进程 RSS(由定义).

  • SIDEKIQ_MEMORY_KILLER_MAX_RSS (KB):如果设置了此变量,并且其值大于 0,则启用 MemoryKiller. 否则,将禁用 MemoryKiller.

    SIDEKIQ_MEMORY_KILLER_MAX_RSS定义了 Sidekiq 进程允许的 RSS.

    传统模式下,如果 Sidekiq 进程超出允许的 RSS,则将触发不可逆的延迟正常重启. Sidekiq 的重启将在SIDEKIQ_MEMORY_KILLER_GRACE_TIME秒后发生.

    Omnibus 软件包的默认值 .

  • SIDEKIQ_MEMORY_KILLER_CHECK_INTERVAL :在守护程序模式下用于定义检查进程 RSS 的频率,默认为 3 秒.

  • SIDEKIQ_MEMORY_KILLER_GRACE_TIME :默认为 900 秒(15 分钟). 此变量的用法描述为SIDEKIQ_MEMORY_KILLER_MAX_RSS一部分.