Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
5e403c3a
Commit
5e403c3a
authored
Aug 02, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
a15389b4
388bbbfd
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
50 additions
and
54 deletions
+50
-54
bin/web_puma
bin/web_puma
+1
-1
changelogs/unreleased/63571-fix-gc-profiler-data-being-wiped.yml
...ogs/unreleased/63571-fix-gc-profiler-data-being-wiped.yml
+5
-0
changelogs/unreleased/fix-bin-web-puma-script-to-consider-rails-env.yml
...eleased/fix-bin-web-puma-script-to-consider-rails-env.yml
+5
-0
config/initializers/peek.rb
config/initializers/peek.rb
+6
-1
lib/gitlab/metrics/samplers/influx_sampler.rb
lib/gitlab/metrics/samplers/influx_sampler.rb
+0
-22
lib/gitlab/metrics/samplers/ruby_sampler.rb
lib/gitlab/metrics/samplers/ruby_sampler.rb
+17
-6
spec/lib/gitlab/metrics/samplers/influx_sampler_spec.rb
spec/lib/gitlab/metrics/samplers/influx_sampler_spec.rb
+0
-20
spec/lib/gitlab/metrics/samplers/ruby_sampler_spec.rb
spec/lib/gitlab/metrics/samplers/ruby_sampler_spec.rb
+16
-4
No files found.
bin/web_puma
View file @
5e403c3a
...
@@ -10,7 +10,7 @@ puma_config="$app_root/config/puma.rb"
...
@@ -10,7 +10,7 @@ puma_config="$app_root/config/puma.rb"
spawn_puma
()
spawn_puma
()
{
{
exec
bundle
exec
puma
--config
"
${
puma_config
}
"
"
$@
"
exec
bundle
exec
puma
--config
"
${
puma_config
}
"
--environment
"
$RAILS_ENV
"
"
$@
"
}
}
get_puma_pid
()
get_puma_pid
()
...
...
changelogs/unreleased/63571-fix-gc-profiler-data-being-wiped.yml
0 → 100644
View file @
5e403c3a
---
title
:
Fix GC::Profiler metrics fetching
merge_request
:
31331
author
:
type
:
fixed
changelogs/unreleased/fix-bin-web-puma-script-to-consider-rails-env.yml
0 → 100644
View file @
5e403c3a
---
title
:
Make `bin/web_puma` consider RAILS_ENV
merge_request
:
31378
author
:
type
:
fixed
config/initializers/peek.rb
View file @
5e403c3a
...
@@ -9,5 +9,10 @@ Peek.into Peek::Views::ActiveRecord
...
@@ -9,5 +9,10 @@ Peek.into Peek::Views::ActiveRecord
Peek
.
into
Peek
::
Views
::
Gitaly
Peek
.
into
Peek
::
Views
::
Gitaly
Peek
.
into
Peek
::
Views
::
RedisDetailed
Peek
.
into
Peek
::
Views
::
RedisDetailed
Peek
.
into
Peek
::
Views
::
Rugged
Peek
.
into
Peek
::
Views
::
Rugged
Peek
.
into
Peek
::
Views
::
GC
# `Peek::Views::GC` is currently disabled in production, as it runs with every request
# even if PerformanceBar is inactive and clears `GC::Profiler` reports we need for metrics.
# Check https://gitlab.com/gitlab-org/gitlab-ce/issues/65455
Peek
.
into
Peek
::
Views
::
GC
if
Rails
.
env
.
development?
Peek
.
into
Peek
::
Views
::
Tracing
if
Labkit
::
Tracing
.
tracing_url_enabled?
Peek
.
into
Peek
::
Views
::
Tracing
if
Labkit
::
Tracing
.
tracing_url_enabled?
lib/gitlab/metrics/samplers/influx_sampler.rb
View file @
5e403c3a
...
@@ -15,19 +15,14 @@ module Gitlab
...
@@ -15,19 +15,14 @@ module Gitlab
@last_step
=
nil
@last_step
=
nil
@metrics
=
[]
@metrics
=
[]
@last_minor_gc
=
Delta
.
new
(
GC
.
stat
[
:minor_gc_count
])
@last_major_gc
=
Delta
.
new
(
GC
.
stat
[
:major_gc_count
])
end
end
def
sample
def
sample
sample_memory_usage
sample_memory_usage
sample_file_descriptors
sample_file_descriptors
sample_gc
flush
flush
ensure
ensure
GC
::
Profiler
.
clear
@metrics
.
clear
@metrics
.
clear
end
end
...
@@ -43,23 +38,6 @@ module Gitlab
...
@@ -43,23 +38,6 @@ module Gitlab
add_metric
(
'file_descriptors'
,
value:
System
.
file_descriptor_count
)
add_metric
(
'file_descriptors'
,
value:
System
.
file_descriptor_count
)
end
end
def
sample_gc
time
=
GC
::
Profiler
.
total_time
*
1000.0
stats
=
GC
.
stat
.
merge
(
total_time:
time
)
# We want the difference of GC runs compared to the last sample, not the
# total amount since the process started.
stats
[
:minor_gc_count
]
=
@last_minor_gc
.
compared_with
(
stats
[
:minor_gc_count
])
stats
[
:major_gc_count
]
=
@last_major_gc
.
compared_with
(
stats
[
:major_gc_count
])
stats
[
:count
]
=
stats
[
:minor_gc_count
]
+
stats
[
:major_gc_count
]
add_metric
(
'gc_statistics'
,
stats
)
end
def
add_metric
(
series
,
values
,
tags
=
{})
def
add_metric
(
series
,
values
,
tags
=
{})
prefix
=
sidekiq?
?
'sidekiq_'
:
'rails_'
prefix
=
sidekiq?
?
'sidekiq_'
:
'rails_'
...
...
lib/gitlab/metrics/samplers/ruby_sampler.rb
View file @
5e403c3a
...
@@ -6,7 +6,11 @@ module Gitlab
...
@@ -6,7 +6,11 @@ module Gitlab
module
Metrics
module
Metrics
module
Samplers
module
Samplers
class
RubySampler
<
BaseSampler
class
RubySampler
<
BaseSampler
GC_REPORT_BUCKETS
=
[
0.001
,
0.002
,
0.005
,
0.01
,
0.05
,
0.1
,
0.5
].
freeze
def
initialize
(
interval
)
def
initialize
(
interval
)
GC
::
Profiler
.
clear
metrics
[
:process_start_time_seconds
].
set
(
labels
,
Time
.
now
.
to_i
)
metrics
[
:process_start_time_seconds
].
set
(
labels
,
Time
.
now
.
to_i
)
super
super
...
@@ -37,7 +41,7 @@ module Gitlab
...
@@ -37,7 +41,7 @@ module Gitlab
process_resident_memory_bytes:
::
Gitlab
::
Metrics
.
gauge
(
with_prefix
(
:process
,
:resident_memory_bytes
),
'Memory used'
,
labels
),
process_resident_memory_bytes:
::
Gitlab
::
Metrics
.
gauge
(
with_prefix
(
:process
,
:resident_memory_bytes
),
'Memory used'
,
labels
),
process_start_time_seconds:
::
Gitlab
::
Metrics
.
gauge
(
with_prefix
(
:process
,
:start_time_seconds
),
'Process start time seconds'
),
process_start_time_seconds:
::
Gitlab
::
Metrics
.
gauge
(
with_prefix
(
:process
,
:start_time_seconds
),
'Process start time seconds'
),
sampler_duration:
::
Gitlab
::
Metrics
.
counter
(
with_prefix
(
:sampler
,
:duration_seconds_total
),
'Sampler time'
,
labels
),
sampler_duration:
::
Gitlab
::
Metrics
.
counter
(
with_prefix
(
:sampler
,
:duration_seconds_total
),
'Sampler time'
,
labels
),
total_time:
::
Gitlab
::
Metrics
.
counter
(
with_prefix
(
:gc
,
:duration_seconds_total
),
'Total GC time'
,
labels
)
gc_duration_seconds:
::
Gitlab
::
Metrics
.
histogram
(
with_prefix
(
:gc
,
:duration_seconds
),
'GC time'
,
labels
,
GC_REPORT_BUCKETS
)
}
}
GC
.
stat
.
keys
.
each
do
|
key
|
GC
.
stat
.
keys
.
each
do
|
key
|
...
@@ -57,20 +61,27 @@ module Gitlab
...
@@ -57,20 +61,27 @@ module Gitlab
sample_gc
sample_gc
metrics
[
:sampler_duration
].
increment
(
labels
,
System
.
monotonic_time
-
start_time
)
metrics
[
:sampler_duration
].
increment
(
labels
,
System
.
monotonic_time
-
start_time
)
ensure
GC
::
Profiler
.
clear
end
end
private
private
def
sample_gc
def
sample_gc
# Collect generic GC stats.
# Observe all GC samples
sample_gc_reports
.
each
do
|
report
|
metrics
[
:gc_duration_seconds
].
observe
(
labels
,
report
[
:GC_TIME
])
end
# Collect generic GC stats
GC
.
stat
.
each
do
|
key
,
value
|
GC
.
stat
.
each
do
|
key
,
value
|
metrics
[
key
].
set
(
labels
,
value
)
metrics
[
key
].
set
(
labels
,
value
)
end
end
end
# Collect the GC time since last sample in float seconds.
def
sample_gc_reports
metrics
[
:total_time
].
increment
(
labels
,
GC
::
Profiler
.
total_time
)
GC
::
Profiler
.
enable
GC
::
Profiler
.
raw_data
ensure
GC
::
Profiler
.
clear
end
end
def
set_memory_usage_metrics
def
set_memory_usage_metrics
...
...
spec/lib/gitlab/metrics/samplers/influx_sampler_spec.rb
View file @
5e403c3a
...
@@ -17,18 +17,10 @@ describe Gitlab::Metrics::Samplers::InfluxSampler do
...
@@ -17,18 +17,10 @@ describe Gitlab::Metrics::Samplers::InfluxSampler do
it
'samples various statistics'
do
it
'samples various statistics'
do
expect
(
sampler
).
to
receive
(
:sample_memory_usage
)
expect
(
sampler
).
to
receive
(
:sample_memory_usage
)
expect
(
sampler
).
to
receive
(
:sample_file_descriptors
)
expect
(
sampler
).
to
receive
(
:sample_file_descriptors
)
expect
(
sampler
).
to
receive
(
:sample_gc
)
expect
(
sampler
).
to
receive
(
:flush
)
expect
(
sampler
).
to
receive
(
:flush
)
sampler
.
sample
sampler
.
sample
end
end
it
'clears any GC profiles'
do
expect
(
sampler
).
to
receive
(
:flush
)
expect
(
GC
::
Profiler
).
to
receive
(
:clear
)
sampler
.
sample
end
end
end
describe
'#flush'
do
describe
'#flush'
do
...
@@ -67,18 +59,6 @@ describe Gitlab::Metrics::Samplers::InfluxSampler do
...
@@ -67,18 +59,6 @@ describe Gitlab::Metrics::Samplers::InfluxSampler do
end
end
end
end
describe
'#sample_gc'
do
it
'adds a metric containing garbage collection statistics'
do
expect
(
GC
::
Profiler
).
to
receive
(
:total_time
).
and_return
(
0.24
)
expect
(
sampler
).
to
receive
(
:add_metric
)
.
with
(
/gc_statistics/
,
an_instance_of
(
Hash
))
.
and_call_original
sampler
.
sample_gc
end
end
describe
'#add_metric'
do
describe
'#add_metric'
do
it
'prefixes the series name for a Rails process'
do
it
'prefixes the series name for a Rails process'
do
expect
(
sampler
).
to
receive
(
:sidekiq?
).
and_return
(
false
)
expect
(
sampler
).
to
receive
(
:sidekiq?
).
and_return
(
false
)
...
...
spec/lib/gitlab/metrics/samplers/ruby_sampler_spec.rb
View file @
5e403c3a
...
@@ -59,17 +59,29 @@ describe Gitlab::Metrics::Samplers::RubySampler do
...
@@ -59,17 +59,29 @@ describe Gitlab::Metrics::Samplers::RubySampler do
end
end
it
'clears any GC profiles'
do
it
'clears any GC profiles'
do
expect
(
GC
::
Profiler
).
to
receive
(
:clear
)
expect
(
GC
::
Profiler
).
to
receive
(
:clear
)
.
at_least
(
:once
)
sampler
.
sample
sampler
.
sample
end
end
end
end
describe
'#sample_gc'
do
describe
'#sample_gc'
do
it
'adds a metric containing garbage collection time statistics'
do
let!
(
:sampler
)
{
described_class
.
new
(
5
)
}
expect
(
GC
::
Profiler
).
to
receive
(
:total_time
).
and_return
(
0.24
)
expect
(
sampler
.
metrics
[
:total_time
]).
to
receive
(
:increment
).
with
({},
0.24
)
let
(
:gc_reports
)
{
[{
GC_TIME
:
0.1
},
{
GC_TIME
:
0.2
},
{
GC_TIME
:
0.3
}]
}
it
're-enables GC::Profiler if needed'
do
expect
(
GC
::
Profiler
).
to
receive
(
:enable
)
sampler
.
sample
end
it
'observes GC cycles time'
do
expect
(
sampler
).
to
receive
(
:sample_gc_reports
).
and_return
(
gc_reports
)
expect
(
sampler
.
metrics
[
:gc_duration_seconds
]).
to
receive
(
:observe
).
with
({},
0.1
).
ordered
expect
(
sampler
.
metrics
[
:gc_duration_seconds
]).
to
receive
(
:observe
).
with
({},
0.2
).
ordered
expect
(
sampler
.
metrics
[
:gc_duration_seconds
]).
to
receive
(
:observe
).
with
({},
0.3
).
ordered
sampler
.
sample
sampler
.
sample
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment