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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
1dbf7284
Commit
1dbf7284
authored
Dec 29, 2015
by
Yorick Peterse
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'influxdb-without-sidekiq' into 'master'
See merge request !2238
parents
10491c38
620e7bb3
Changes
19
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
155 additions
and
155 deletions
+155
-155
Procfile
Procfile
+1
-1
app/controllers/admin/application_settings_controller.rb
app/controllers/admin/application_settings_controller.rb
+1
-1
app/views/admin/application_settings/_form.html.haml
app/views/admin/application_settings/_form.html.haml
+6
-4
app/workers/metrics_worker.rb
app/workers/metrics_worker.rb
+0
-33
db/migrate/20151229102248_influxdb_udp_port_setting.rb
db/migrate/20151229102248_influxdb_udp_port_setting.rb
+5
-0
db/migrate/20151229112614_influxdb_remote_database_setting.rb
...igrate/20151229112614_influxdb_remote_database_setting.rb
+5
-0
db/schema.rb
db/schema.rb
+41
-41
lib/gitlab/metrics.rb
lib/gitlab/metrics.rb
+36
-2
lib/gitlab/metrics/metric.rb
lib/gitlab/metrics/metric.rb
+1
-1
lib/gitlab/metrics/obfuscated_sql.rb
lib/gitlab/metrics/obfuscated_sql.rb
+1
-1
lib/gitlab/metrics/sampler.rb
lib/gitlab/metrics/sampler.rb
+1
-1
lib/gitlab/metrics/sidekiq_middleware.rb
lib/gitlab/metrics/sidekiq_middleware.rb
+0
-7
lib/gitlab/metrics/transaction.rb
lib/gitlab/metrics/transaction.rb
+1
-1
spec/lib/gitlab/metrics/obfuscated_sql_spec.rb
spec/lib/gitlab/metrics/obfuscated_sql_spec.rb
+6
-0
spec/lib/gitlab/metrics/sampler_spec.rb
spec/lib/gitlab/metrics/sampler_spec.rb
+1
-1
spec/lib/gitlab/metrics/sidekiq_middleware_spec.rb
spec/lib/gitlab/metrics/sidekiq_middleware_spec.rb
+0
-8
spec/lib/gitlab/metrics/transaction_spec.rb
spec/lib/gitlab/metrics/transaction_spec.rb
+1
-1
spec/lib/gitlab/metrics_spec.rb
spec/lib/gitlab/metrics_spec.rb
+48
-0
spec/workers/metrics_worker_spec.rb
spec/workers/metrics_worker_spec.rb
+0
-52
No files found.
Procfile
View file @
1dbf7284
...
@@ -3,5 +3,5 @@
...
@@ -3,5 +3,5 @@
# lib/support/init.d, which call scripts in bin/ .
# lib/support/init.d, which call scripts in bin/ .
#
#
web: bundle exec unicorn_rails -p ${PORT:="3000"} -E ${RAILS_ENV:="development"} -c ${UNICORN_CONFIG:="config/unicorn.rb"}
web: bundle exec unicorn_rails -p ${PORT:="3000"} -E ${RAILS_ENV:="development"} -c ${UNICORN_CONFIG:="config/unicorn.rb"}
worker: bundle exec sidekiq -q post_receive -q mailers -q archive_repo -q system_hook -q project_web_hook -q gitlab_shell -q incoming_email -q runner -q common -q default
-q metrics
worker: bundle exec sidekiq -q post_receive -q mailers -q archive_repo -q system_hook -q project_web_hook -q gitlab_shell -q incoming_email -q runner -q common -q default
# mail_room: bundle exec mail_room -q -c config/mail_room.yml
# mail_room: bundle exec mail_room -q -c config/mail_room.yml
app/controllers/admin/application_settings_controller.rb
View file @
1dbf7284
...
@@ -69,7 +69,7 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
...
@@ -69,7 +69,7 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
:max_artifacts_size
,
:max_artifacts_size
,
:metrics_enabled
,
:metrics_enabled
,
:metrics_host
,
:metrics_host
,
:metrics_
database
,
:metrics_
port
,
:metrics_username
,
:metrics_username
,
:metrics_password
,
:metrics_password
,
:metrics_pool_size
,
:metrics_pool_size
,
...
...
app/views/admin/application_settings/_form.html.haml
View file @
1dbf7284
...
@@ -171,12 +171,14 @@
...
@@ -171,12 +171,14 @@
.col-sm-10
.col-sm-10
=
f
.
text_field
:metrics_host
,
class:
'form-control'
,
placeholder:
'influxdb.example.com'
=
f
.
text_field
:metrics_host
,
class:
'form-control'
,
placeholder:
'influxdb.example.com'
.form-group
.form-group
=
f
.
label
:metrics_
database
,
'InfluxDB database
'
,
class:
'control-label col-sm-2'
=
f
.
label
:metrics_
port
,
'InfluxDB port
'
,
class:
'control-label col-sm-2'
.col-sm-10
.col-sm-10
=
f
.
text_field
:metrics_
database
,
class:
'form-control'
,
placeholder:
'gitlab
'
=
f
.
text_field
:metrics_
port
,
class:
'form-control'
,
placeholder:
'8089
'
.help-block
.help-block
The name of the InfluxDB database to store data in. Users will have to
The UDP port to use for connecting to InfluxDB. InfluxDB requires that
create this database manually, GitLab does not do so automatically.
your server configuration specifies a database to store data in when
sending messages to this port, without it metrics data will not be
saved.
.form-group
.form-group
=
f
.
label
:metrics_username
,
'InfluxDB username'
,
class:
'control-label col-sm-2'
=
f
.
label
:metrics_username
,
'InfluxDB username'
,
class:
'control-label col-sm-2'
.col-sm-10
.col-sm-10
...
...
app/workers/metrics_worker.rb
deleted
100644 → 0
View file @
10491c38
class
MetricsWorker
include
Sidekiq
::
Worker
sidekiq_options
queue: :metrics
def
perform
(
metrics
)
prepared
=
prepare_metrics
(
metrics
)
Gitlab
::
Metrics
.
pool
.
with
do
|
connection
|
connection
.
write_points
(
prepared
)
end
end
def
prepare_metrics
(
metrics
)
metrics
.
map
do
|
hash
|
new_hash
=
hash
.
symbolize_keys
new_hash
[
:tags
].
each
do
|
key
,
value
|
if
value
.
blank?
new_hash
[
:tags
].
delete
(
key
)
else
new_hash
[
:tags
][
key
]
=
escape_value
(
value
)
end
end
new_hash
end
end
def
escape_value
(
value
)
value
.
to_s
.
gsub
(
'='
,
'\\='
)
end
end
db/migrate/20151229102248_influxdb_udp_port_setting.rb
0 → 100644
View file @
1dbf7284
class
InfluxdbUdpPortSetting
<
ActiveRecord
::
Migration
def
change
add_column
:application_settings
,
:metrics_port
,
:integer
,
default:
8089
end
end
db/migrate/20151229112614_influxdb_remote_database_setting.rb
0 → 100644
View file @
1dbf7284
class
InfluxdbRemoteDatabaseSetting
<
ActiveRecord
::
Migration
def
change
remove_column
:application_settings
,
:metrics_database
end
end
db/schema.rb
View file @
1dbf7284
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
#
#
# It's strongly recommended that you check this file into your version control system.
# It's strongly recommended that you check this file into your version control system.
ActiveRecord
::
Schema
.
define
(
version:
2015122
8175719
)
do
ActiveRecord
::
Schema
.
define
(
version:
2015122
9112614
)
do
# These are extensions that must be enabled in order to support this database
# These are extensions that must be enabled in order to support this database
enable_extension
"plpgsql"
enable_extension
"plpgsql"
...
@@ -54,7 +54,6 @@ ActiveRecord::Schema.define(version: 20151228175719) do
...
@@ -54,7 +54,6 @@ ActiveRecord::Schema.define(version: 20151228175719) do
t
.
integer
"two_factor_grace_period"
,
default:
48
t
.
integer
"two_factor_grace_period"
,
default:
48
t
.
boolean
"metrics_enabled"
,
default:
false
t
.
boolean
"metrics_enabled"
,
default:
false
t
.
string
"metrics_host"
,
default:
"localhost"
t
.
string
"metrics_host"
,
default:
"localhost"
t
.
string
"metrics_database"
,
default:
"gitlab"
t
.
string
"metrics_username"
t
.
string
"metrics_username"
t
.
string
"metrics_password"
t
.
string
"metrics_password"
t
.
integer
"metrics_pool_size"
,
default:
16
t
.
integer
"metrics_pool_size"
,
default:
16
...
@@ -63,6 +62,7 @@ ActiveRecord::Schema.define(version: 20151228175719) do
...
@@ -63,6 +62,7 @@ ActiveRecord::Schema.define(version: 20151228175719) do
t
.
boolean
"recaptcha_enabled"
,
default:
false
t
.
boolean
"recaptcha_enabled"
,
default:
false
t
.
string
"recaptcha_site_key"
t
.
string
"recaptcha_site_key"
t
.
string
"recaptcha_private_key"
t
.
string
"recaptcha_private_key"
t
.
integer
"metrics_port"
,
default:
8089
end
end
create_table
"audit_events"
,
force: :cascade
do
|
t
|
create_table
"audit_events"
,
force: :cascade
do
|
t
|
...
...
lib/gitlab/metrics.rb
View file @
1dbf7284
...
@@ -66,6 +66,39 @@ module Gitlab
...
@@ -66,6 +66,39 @@ module Gitlab
end
end
end
end
def
self
.
submit_metrics
(
metrics
)
prepared
=
prepare_metrics
(
metrics
)
pool
.
with
do
|
connection
|
prepared
.
each
do
|
metric
|
begin
connection
.
write_points
([
metric
])
rescue
StandardError
end
end
end
end
def
self
.
prepare_metrics
(
metrics
)
metrics
.
map
do
|
hash
|
new_hash
=
hash
.
symbolize_keys
new_hash
[
:tags
].
each
do
|
key
,
value
|
if
value
.
blank?
new_hash
[
:tags
].
delete
(
key
)
else
new_hash
[
:tags
][
key
]
=
escape_value
(
value
)
end
end
new_hash
end
end
def
self
.
escape_value
(
value
)
value
.
to_s
.
gsub
(
'='
,
'\\='
)
end
@hostname
=
Socket
.
gethostname
@hostname
=
Socket
.
gethostname
# When enabled this should be set before being used as the usual pattern
# When enabled this should be set before being used as the usual pattern
...
@@ -73,11 +106,12 @@ module Gitlab
...
@@ -73,11 +106,12 @@ module Gitlab
if
enabled?
if
enabled?
@pool
=
ConnectionPool
.
new
(
size:
pool_size
,
timeout:
timeout
)
do
@pool
=
ConnectionPool
.
new
(
size:
pool_size
,
timeout:
timeout
)
do
host
=
settings
[
:metrics_host
]
host
=
settings
[
:metrics_host
]
db
=
settings
[
:metrics_database
]
user
=
settings
[
:metrics_username
]
user
=
settings
[
:metrics_username
]
pw
=
settings
[
:metrics_password
]
pw
=
settings
[
:metrics_password
]
port
=
settings
[
:metrics_port
]
InfluxDB
::
Client
.
new
(
db
,
host:
host
,
username:
user
,
password:
pw
)
InfluxDB
::
Client
.
new
(
udp:
{
host:
host
,
port:
port
},
username:
user
,
password:
pw
)
end
end
end
end
end
end
...
...
lib/gitlab/metrics/metric.rb
View file @
1dbf7284
...
@@ -26,7 +26,7 @@ module Gitlab
...
@@ -26,7 +26,7 @@ module Gitlab
process_type:
Sidekiq
.
server?
?
'sidekiq'
:
'rails'
process_type:
Sidekiq
.
server?
?
'sidekiq'
:
'rails'
),
),
values:
@values
,
values:
@values
,
timestamp:
@created_at
.
to_i
timestamp:
@created_at
.
to_i
*
1_000_000_000
}
}
end
end
end
end
...
...
lib/gitlab/metrics/obfuscated_sql.rb
View file @
1dbf7284
...
@@ -40,7 +40,7 @@ module Gitlab
...
@@ -40,7 +40,7 @@ module Gitlab
sql
=
sql
.
delete
(
'"'
)
sql
=
sql
.
delete
(
'"'
)
end
end
sql
sql
.
tr
(
"
\n
"
,
' '
)
end
end
end
end
end
end
...
...
lib/gitlab/metrics/sampler.rb
View file @
1dbf7284
...
@@ -46,7 +46,7 @@ module Gitlab
...
@@ -46,7 +46,7 @@ module Gitlab
end
end
def
flush
def
flush
Metrics
Worker
.
perform_async
(
@metrics
.
map
(
&
:to_hash
))
Metrics
.
submit_metrics
(
@metrics
.
map
(
&
:to_hash
))
end
end
def
sample_memory_usage
def
sample_memory_usage
...
...
lib/gitlab/metrics/sidekiq_middleware.rb
View file @
1dbf7284
...
@@ -5,13 +5,6 @@ module Gitlab
...
@@ -5,13 +5,6 @@ module Gitlab
# This middleware is intended to be used as a server-side middleware.
# This middleware is intended to be used as a server-side middleware.
class
SidekiqMiddleware
class
SidekiqMiddleware
def
call
(
worker
,
message
,
queue
)
def
call
(
worker
,
message
,
queue
)
# We don't want to track the MetricsWorker itself as otherwise we'll end
# up in an infinite loop.
if
worker
.
class
==
MetricsWorker
yield
return
end
trans
=
Transaction
.
new
trans
=
Transaction
.
new
begin
begin
...
...
lib/gitlab/metrics/transaction.rb
View file @
1dbf7284
...
@@ -59,7 +59,7 @@ module Gitlab
...
@@ -59,7 +59,7 @@ module Gitlab
end
end
def
submit
def
submit
Metrics
Worker
.
perform_async
(
@metrics
.
map
(
&
:to_hash
))
Metrics
.
submit_metrics
(
@metrics
.
map
(
&
:to_hash
))
end
end
end
end
end
end
...
...
spec/lib/gitlab/metrics/obfuscated_sql_spec.rb
View file @
1dbf7284
...
@@ -2,6 +2,12 @@ require 'spec_helper'
...
@@ -2,6 +2,12 @@ require 'spec_helper'
describe
Gitlab
::
Metrics
::
ObfuscatedSQL
do
describe
Gitlab
::
Metrics
::
ObfuscatedSQL
do
describe
'#to_s'
do
describe
'#to_s'
do
it
'replaces newlines with a space'
do
sql
=
described_class
.
new
(
"SELECT x
\n
FROM y"
)
expect
(
sql
.
to_s
).
to
eq
(
'SELECT x FROM y'
)
end
describe
'using single values'
do
describe
'using single values'
do
it
'replaces a single integer'
do
it
'replaces a single integer'
do
sql
=
described_class
.
new
(
'SELECT x FROM y WHERE a = 10'
)
sql
=
described_class
.
new
(
'SELECT x FROM y WHERE a = 10'
)
...
...
spec/lib/gitlab/metrics/sampler_spec.rb
View file @
1dbf7284
...
@@ -38,7 +38,7 @@ describe Gitlab::Metrics::Sampler do
...
@@ -38,7 +38,7 @@ describe Gitlab::Metrics::Sampler do
describe
'#flush'
do
describe
'#flush'
do
it
'schedules the metrics using Sidekiq'
do
it
'schedules the metrics using Sidekiq'
do
expect
(
MetricsWorker
).
to
receive
(
:perform_async
).
expect
(
Gitlab
::
Metrics
).
to
receive
(
:submit_metrics
).
with
([
an_instance_of
(
Hash
)])
with
([
an_instance_of
(
Hash
)])
sampler
.
sample_memory_usage
sampler
.
sample_memory_usage
...
...
spec/lib/gitlab/metrics/sidekiq_middleware_spec.rb
View file @
1dbf7284
...
@@ -11,14 +11,6 @@ describe Gitlab::Metrics::SidekiqMiddleware do
...
@@ -11,14 +11,6 @@ describe Gitlab::Metrics::SidekiqMiddleware do
middleware
.
call
(
worker
,
'test'
,
:test
)
{
nil
}
middleware
.
call
(
worker
,
'test'
,
:test
)
{
nil
}
end
end
it
'does not track jobs of the MetricsWorker'
do
worker
=
MetricsWorker
.
new
expect
(
Gitlab
::
Metrics
::
Transaction
).
to_not
receive
(
:new
)
middleware
.
call
(
worker
,
'test'
,
:test
)
{
nil
}
end
end
end
describe
'#tag_worker'
do
describe
'#tag_worker'
do
...
...
spec/lib/gitlab/metrics/transaction_spec.rb
View file @
1dbf7284
...
@@ -68,7 +68,7 @@ describe Gitlab::Metrics::Transaction do
...
@@ -68,7 +68,7 @@ describe Gitlab::Metrics::Transaction do
it
'submits the metrics to Sidekiq'
do
it
'submits the metrics to Sidekiq'
do
transaction
.
track_self
transaction
.
track_self
expect
(
MetricsWorker
).
to
receive
(
:perform_async
).
expect
(
Gitlab
::
Metrics
).
to
receive
(
:submit_metrics
).
with
([
an_instance_of
(
Hash
)])
with
([
an_instance_of
(
Hash
)])
transaction
.
submit
transaction
.
submit
...
...
spec/lib/gitlab/metrics_spec.rb
View file @
1dbf7284
...
@@ -33,4 +33,52 @@ describe Gitlab::Metrics do
...
@@ -33,4 +33,52 @@ describe Gitlab::Metrics do
expect
(
file
).
to
eq
(
'spec/lib/gitlab/metrics_spec.rb'
)
expect
(
file
).
to
eq
(
'spec/lib/gitlab/metrics_spec.rb'
)
end
end
end
end
describe
'#submit_metrics'
do
it
'prepares and writes the metrics to InfluxDB'
do
connection
=
double
(
:connection
)
pool
=
double
(
:pool
)
expect
(
pool
).
to
receive
(
:with
).
and_yield
(
connection
)
expect
(
connection
).
to
receive
(
:write_points
).
with
(
an_instance_of
(
Array
))
expect
(
Gitlab
::
Metrics
).
to
receive
(
:pool
).
and_return
(
pool
)
described_class
.
submit_metrics
([{
'series'
=>
'kittens'
,
'tags'
=>
{}
}])
end
end
describe
'#prepare_metrics'
do
it
'returns a Hash with the keys as Symbols'
do
metrics
=
described_class
.
prepare_metrics
([{
'values'
=>
{},
'tags'
=>
{}
}])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{}
}])
end
it
'escapes tag values'
do
metrics
=
described_class
.
prepare_metrics
([
{
'values'
=>
{},
'tags'
=>
{
'foo'
=>
'bar='
}
}
])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{
'foo'
=>
'bar\\='
}
}])
end
it
'drops empty tags'
do
metrics
=
described_class
.
prepare_metrics
([
{
'values'
=>
{},
'tags'
=>
{
'cats'
=>
''
,
'dogs'
=>
nil
}
}
])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{}
}])
end
end
describe
'#escape_value'
do
it
'escapes an equals sign'
do
expect
(
described_class
.
escape_value
(
'foo='
)).
to
eq
(
'foo\\='
)
end
it
'casts values to Strings'
do
expect
(
described_class
.
escape_value
(
10
)).
to
eq
(
'10'
)
end
end
end
end
spec/workers/metrics_worker_spec.rb
deleted
100644 → 0
View file @
10491c38
require
'spec_helper'
describe
MetricsWorker
do
let
(
:worker
)
{
described_class
.
new
}
describe
'#perform'
do
it
'prepares and writes the metrics to InfluxDB'
do
connection
=
double
(
:connection
)
pool
=
double
(
:pool
)
expect
(
pool
).
to
receive
(
:with
).
and_yield
(
connection
)
expect
(
connection
).
to
receive
(
:write_points
).
with
(
an_instance_of
(
Array
))
expect
(
Gitlab
::
Metrics
).
to
receive
(
:pool
).
and_return
(
pool
)
worker
.
perform
([{
'series'
=>
'kittens'
,
'tags'
=>
{}
}])
end
end
describe
'#prepare_metrics'
do
it
'returns a Hash with the keys as Symbols'
do
metrics
=
worker
.
prepare_metrics
([{
'values'
=>
{},
'tags'
=>
{}
}])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{}
}])
end
it
'escapes tag values'
do
metrics
=
worker
.
prepare_metrics
([
{
'values'
=>
{},
'tags'
=>
{
'foo'
=>
'bar='
}
}
])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{
'foo'
=>
'bar\\='
}
}])
end
it
'drops empty tags'
do
metrics
=
worker
.
prepare_metrics
([
{
'values'
=>
{},
'tags'
=>
{
'cats'
=>
''
,
'dogs'
=>
nil
}
}
])
expect
(
metrics
).
to
eq
([{
values:
{},
tags:
{}
}])
end
end
describe
'#escape_value'
do
it
'escapes an equals sign'
do
expect
(
worker
.
escape_value
(
'foo='
)).
to
eq
(
'foo\\='
)
end
it
'casts values to Strings'
do
expect
(
worker
.
escape_value
(
10
)).
to
eq
(
'10'
)
end
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