Commit 1d3e7aa9 authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch 'bjk/32646_puma_killer' into 'master'

Update PumaWorkerKiller defaults

Closes #32646

See merge request gitlab-org/gitlab!17758
parents 56286f28 e03bb250
---
title: Update PumaWorkerKiller defaults
merge_request: 17758
author:
type: performance
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Gitlab module Gitlab
module Cluster module Cluster
class PumaWorkerKillerInitializer class PumaWorkerKillerInitializer
def self.start(puma_options, puma_per_worker_max_memory_mb: 650) def self.start(puma_options, puma_per_worker_max_memory_mb: 850, puma_master_max_memory_mb: 550)
require 'puma_worker_killer' require 'puma_worker_killer'
PumaWorkerKiller.config do |config| PumaWorkerKiller.config do |config|
...@@ -12,10 +12,9 @@ module Gitlab ...@@ -12,10 +12,9 @@ module Gitlab
# not each worker as is the case with GITLAB_UNICORN_MEMORY_MAX # not each worker as is the case with GITLAB_UNICORN_MEMORY_MAX
worker_count = puma_options[:workers] || 1 worker_count = puma_options[:workers] || 1
# The Puma Worker Killer checks the total RAM used by both the master # The Puma Worker Killer checks the total RAM used by both the master
# and worker processes. Bump the limits to N+1 instead of N workers # and worker processes.
# to account for this:
# https://github.com/schneems/puma_worker_killer/blob/v0.1.0/lib/puma_worker_killer/puma_memory.rb#L57 # https://github.com/schneems/puma_worker_killer/blob/v0.1.0/lib/puma_worker_killer/puma_memory.rb#L57
config.ram = (worker_count + 1) * puma_per_worker_max_memory_mb config.ram = puma_master_max_memory_mb + (worker_count * puma_per_worker_max_memory_mb)
config.frequency = 20 # seconds config.frequency = 20 # seconds
...@@ -23,10 +22,9 @@ module Gitlab ...@@ -23,10 +22,9 @@ module Gitlab
# of available RAM. # of available RAM.
config.percent_usage = 0.98 config.percent_usage = 0.98
# Ideally we'll never hit the maximum amount of memory. If so the worker # Ideally we'll never hit the maximum amount of memory. Restart the workers
# is restarted already, thus periodically restarting workers shouldn't be # regularly rather than rely on OOM behavior for periodic restarting.
# needed. config.rolling_restart_frequency = 43200 # 12 hours in seconds.
config.rolling_restart_frequency = false
observer = Gitlab::Cluster::PumaWorkerKillerObserver.new observer = Gitlab::Cluster::PumaWorkerKillerObserver.new
config.pre_term = observer.callback config.pre_term = observer.callback
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment