Commit ad0a0a1e authored by Matthias Käppler's avatar Matthias Käppler Committed by Dylan Griffith

Add mem_total_bytes metric to Memory instrumentation

parent 3cf22743
...@@ -365,14 +365,16 @@ This patch is available by default for ...@@ -365,14 +365,16 @@ This patch is available by default for
[GCK](https://gitlab.com/gitlab-org/gitlab-compose-kit/-/merge_requests/149) [GCK](https://gitlab.com/gitlab-org/gitlab-compose-kit/-/merge_requests/149)
and can additionally be enabled for [GDK](https://gitlab.com/gitlab-org/gitlab-development-kit/-/blob/main/doc/advanced.md#apply-custom-patches-for-ruby). and can additionally be enabled for [GDK](https://gitlab.com/gitlab-org/gitlab-development-kit/-/blob/main/doc/advanced.md#apply-custom-patches-for-ruby).
This patch provides a set of 3 metrics that makes it easier to understand efficiency of memory usage for a given codepath: This patch provides the following metrics that make it easier to understand efficiency of memory use for a given codepath:
- `mem_total_bytes`: the number of bytes consumed both due to new objects being allocated into existing object slots
plus additional memory allocated for large objects (that is, `mem_bytes + slot_size * mem_objects`).
- `mem_bytes`: the number of bytes allocated by `malloc` for objects that did not fit into an existing object slot.
- `mem_objects`: the number of objects allocated. - `mem_objects`: the number of objects allocated.
- `mem_bytes`: the number of bytes allocated by malloc. - `mem_mallocs`: the number of `malloc` calls.
- `mem_mallocs`: the number of malloc allocations.
The number of objects and bytes allocated impact how often GC cycles happen. The number of objects and bytes allocated impact how often GC cycles happen.
Fewer objects allocations result in a significantly more responsive application. Fewer object allocations result in a significantly more responsive application.
It is advised that web server requests do not allocate more than `100k mem_objects` It is advised that web server requests do not allocate more than `100k mem_objects`
and `100M mem_bytes`. You can view the current usage on [GitLab.com](https://log.gprd.gitlab.net/goto/3a9678bb595e3f89a0c7b5c61bcc47b9). and `100M mem_bytes`. You can view the current usage on [GitLab.com](https://log.gprd.gitlab.net/goto/3a9678bb595e3f89a0c7b5c61bcc47b9).
......
...@@ -45,9 +45,12 @@ module Gitlab ...@@ -45,9 +45,12 @@ module Gitlab
end end
# This method returns a hash with the following keys: # This method returns a hash with the following keys:
# - mem_objects: a number of allocated heap slots (as reflected by GC) # - mem_objects: number of allocated heap slots (as reflected by GC)
# - mem_mallocs: a number of malloc calls # - mem_mallocs: number of malloc calls
# - mem_bytes: a number of bytes allocated with a mallocs tied to heap slots # - mem_bytes: number of bytes allocated by malloc for objects that did not fit
# into a heap slot
# - mem_total_bytes: number of bytes allocated for both objects consuming an object slot
# and objects that required a malloc (mem_malloc_bytes)
def self.measure_thread_memory_allocations(previous) def self.measure_thread_memory_allocations(previous)
return unless available? return unless available?
return unless previous return unless previous
...@@ -56,9 +59,13 @@ module Gitlab ...@@ -56,9 +59,13 @@ module Gitlab
return unless current return unless current
# calculate difference in a memory allocations # calculate difference in a memory allocations
previous.to_h do |key, value| result = previous.to_h do |key, value|
[KEY_MAPPING.fetch(key), current[key].to_i - value] [KEY_MAPPING.fetch(key), current[key].to_i - value]
end end
result[:mem_total_bytes] = result[:mem_bytes] + result[:mem_objects] * GC::INTERNAL_CONSTANTS[:RVALUE_SIZE]
result
end end
def self.with_memory_allocations def self.with_memory_allocations
......
...@@ -69,10 +69,12 @@ RSpec.describe Gitlab::Memory::Instrumentation do ...@@ -69,10 +69,12 @@ RSpec.describe Gitlab::Memory::Instrumentation do
end end
it 'a hash is returned' do it 'a hash is returned' do
is_expected.to include( result = subject
expect(result).to include(
mem_objects: be > 1000, mem_objects: be > 1000,
mem_mallocs: be > 1000, mem_mallocs: be > 1000,
mem_bytes: be > 100_000 # 100 items * 100 bytes each mem_bytes: be > 100_000, # 100 items * 100 bytes each
mem_total_bytes: eq(result[:mem_bytes] + 40 * result[:mem_objects])
) )
end end
end end
......
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