prom_multi_proc_rb 0.1.2 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.gitignore +1 -0
- data/.travis.yml +2 -2
- data/lib/prom_multi_proc/base.rb +6 -2
- data/lib/prom_multi_proc/collector.rb +1 -1
- data/lib/prom_multi_proc/rails.rb +8 -1
- data/lib/prom_multi_proc/version.rb +1 -1
- data/lib/prom_multi_proc/writer.rb +15 -5
- data/prom_multi_proc_rb.gemspec +5 -5
- metadata +15 -22
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: '0208f9f3b13f1d85eb96973791697f077ffa3f560bd843f863e1abbd440e2138'
|
4
|
+
data.tar.gz: '06955b253c46199a3ae8c39bbfd0a655bb790a0e4c50ae69ae46320d5022187d'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 7a592243fc1fff0b882d7c97011c86f794f074526260c7854980b92d86f2742478f1e35ffa220ebf56dc44442f9a5ed4b4c65b29a8ca4651b9ff73ddd6c0ca52
|
7
|
+
data.tar.gz: fdd1ef7cbc98d639aabdedf249ab32224f55a6f253fd6c11958bead30ab6fcdcf4b639af0d17768193e3b69fddd42e54fffd82f0ad74737ab2f19d1259fc6793
|
data/.gitignore
CHANGED
data/.travis.yml
CHANGED
data/lib/prom_multi_proc/base.rb
CHANGED
@@ -5,7 +5,7 @@ module PromMultiProc
|
|
5
5
|
class Base
|
6
6
|
attr_reader :logger, :prefix, :writer
|
7
7
|
|
8
|
-
def initialize(socket:, metrics:, batch_size: 1, logger: nil, validate: false, prefix: "")
|
8
|
+
def initialize(socket:, metrics:, batch_size: 1, batch_timeout: 3, logger: nil, validate: false, prefix: "")
|
9
9
|
@prefix = prefix
|
10
10
|
@logger = logger || ::Logger.new(STDOUT)
|
11
11
|
|
@@ -14,7 +14,7 @@ module PromMultiProc
|
|
14
14
|
end
|
15
15
|
|
16
16
|
@metric_objects = Concurrent::Map.new
|
17
|
-
@writer = Writer.new(socket: socket, batch_size: batch_size, validate: validate)
|
17
|
+
@writer = Writer.new(socket: socket, batch_size: batch_size, batch_timeout: batch_timeout, validate: validate)
|
18
18
|
@multi_lock = Mutex.new
|
19
19
|
|
20
20
|
specs = get_specs(metrics)
|
@@ -80,6 +80,10 @@ module PromMultiProc
|
|
80
80
|
end
|
81
81
|
name = spec["name"].sub(/\A#{prefix}/, "").to_sym
|
82
82
|
|
83
|
+
unless spec["help"] && !spec["help"].strip.empty?
|
84
|
+
raise PromMultiProcError.new("Metric '#{spec['name']}' is missing help")
|
85
|
+
end
|
86
|
+
|
83
87
|
labels = (spec["labels"] || []).map(&:to_sym)
|
84
88
|
unless labels.all? { |l| valid_metric?(l) }
|
85
89
|
raise PromMultiProcError.new("Invalid label: #{spec.inspect}")
|
@@ -21,7 +21,7 @@ module PromMultiProc
|
|
21
21
|
raise PromMultiProcError.new("Invalid label cardinality (#{name}): #{labels.keys.inspect}, need keys: #{@label_keys.inspect}")
|
22
22
|
end
|
23
23
|
unless valid_label_values?(labels)
|
24
|
-
raise PromMultiProcError.new("Invalid label values (#{name}): #{labels.values.inspect}")
|
24
|
+
raise PromMultiProcError.new("Invalid label values (#{name}): #{labels.values.inspect} (all values must be string or symbol)")
|
25
25
|
end
|
26
26
|
unless valid_value?(value)
|
27
27
|
raise PromMultiProcError.new("Invalid value (#{name}): #{value.inspect} (must be numeric)")
|
@@ -20,6 +20,12 @@ module PromMultiProc
|
|
20
20
|
batch_size = 5
|
21
21
|
end
|
22
22
|
|
23
|
+
if ENV.key?("PROM_MULTI_PROC_BATCH_TIMEOUT")
|
24
|
+
batch_timeout = ENV["PROM_MULTI_PROC_BATCH_TIMEOUT"].to_i
|
25
|
+
else
|
26
|
+
batch_timeout = 3
|
27
|
+
end
|
28
|
+
|
23
29
|
if ::Rails.env.development? || ::Rails.env.test?
|
24
30
|
validate = true
|
25
31
|
else
|
@@ -32,13 +38,14 @@ module PromMultiProc
|
|
32
38
|
logger = ::Logger.new(STDOUT)
|
33
39
|
end
|
34
40
|
|
35
|
-
logger.
|
41
|
+
logger.info("Setting up prom_multi_proc for #{app_name}-#{program_name}, batch size: #{batch_size}, batch timeout: #{batch_timeout} validate: #{validate}")
|
36
42
|
|
37
43
|
Base.new(
|
38
44
|
prefix: prefix,
|
39
45
|
socket: socket,
|
40
46
|
metrics: metrics,
|
41
47
|
batch_size: batch_size,
|
48
|
+
batch_timeout: batch_timeout,
|
42
49
|
validate: validate,
|
43
50
|
logger: logger
|
44
51
|
)
|
@@ -1,15 +1,25 @@
|
|
1
1
|
module PromMultiProc
|
2
2
|
class Writer
|
3
|
-
attr_reader :socket, :batch_size
|
3
|
+
attr_reader :socket, :batch_size, :batch_timeout
|
4
4
|
|
5
|
-
def initialize(socket:, batch_size: 1, validate: false)
|
6
|
-
if !batch_size.is_a?(
|
5
|
+
def initialize(socket:, batch_size: 1, batch_timeout: 3, validate: false)
|
6
|
+
if !batch_size.is_a?(Integer) || batch_size <= 0
|
7
7
|
raise PromMultiProcError.new("Invalid batch size: #{batch_size}")
|
8
8
|
end
|
9
|
+
if !batch_timeout.is_a?(Integer) || batch_timeout <= 0
|
10
|
+
raise PromMultiProcError.new("Invalid batch timeout: #{batch_timeout}")
|
11
|
+
end
|
9
12
|
@batch_size = batch_size
|
13
|
+
@batch_timeout = batch_timeout
|
10
14
|
@validate = !!validate
|
11
15
|
|
12
16
|
@lock = Mutex.new
|
17
|
+
@thread = Thread.new {
|
18
|
+
loop do
|
19
|
+
sleep(batch_timeout)
|
20
|
+
flush(force: true)
|
21
|
+
end
|
22
|
+
}
|
13
23
|
@messages = []
|
14
24
|
|
15
25
|
@socket = socket
|
@@ -46,9 +56,9 @@ module PromMultiProc
|
|
46
56
|
flush
|
47
57
|
end
|
48
58
|
|
49
|
-
def flush
|
59
|
+
def flush(force: false)
|
50
60
|
@lock.synchronize do
|
51
|
-
if @messages.length >= batch_size
|
61
|
+
if force && @messages.length > 0 || @messages.length >= batch_size
|
52
62
|
begin
|
53
63
|
write_socket(JSON.generate(@messages))
|
54
64
|
ensure
|
data/prom_multi_proc_rb.gemspec
CHANGED
@@ -30,10 +30,10 @@ Gem::Specification.new do |spec|
|
|
30
30
|
spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
|
31
31
|
spec.require_paths = ["lib"]
|
32
32
|
|
33
|
-
spec.add_development_dependency "bundler", "
|
34
|
-
spec.add_development_dependency "rake", "
|
35
|
-
spec.add_development_dependency "rspec", "~> 3.
|
36
|
-
spec.add_development_dependency "rspec-collection_matchers", "~> 1.
|
33
|
+
spec.add_development_dependency "bundler", ">= 1.15"
|
34
|
+
spec.add_development_dependency "rake", ">= 12.3.3"
|
35
|
+
spec.add_development_dependency "rspec", "~> 3.9"
|
36
|
+
spec.add_development_dependency "rspec-collection_matchers", "~> 1.2"
|
37
37
|
|
38
|
-
spec.add_dependency "concurrent-ruby", "~> 1.
|
38
|
+
spec.add_dependency "concurrent-ruby", "~> 1.1"
|
39
39
|
end
|
metadata
CHANGED
@@ -1,91 +1,85 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: prom_multi_proc_rb
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Andrew Tongen
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-12-03 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- - "
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
19
|
version: '1.15'
|
20
20
|
type: :development
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- - "
|
24
|
+
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: '1.15'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- - "
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
33
|
+
version: 12.3.3
|
34
34
|
type: :development
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- - "
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version:
|
40
|
+
version: 12.3.3
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rspec
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
45
|
- - "~>"
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: '3.
|
47
|
+
version: '3.9'
|
48
48
|
type: :development
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
52
|
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version: '3.
|
54
|
+
version: '3.9'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: rspec-collection_matchers
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
59
|
- - "~>"
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version: '1.
|
61
|
+
version: '1.2'
|
62
62
|
type: :development
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
66
|
- - "~>"
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version: '1.
|
68
|
+
version: '1.2'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: concurrent-ruby
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
73
|
- - "~>"
|
74
74
|
- !ruby/object:Gem::Version
|
75
|
-
version: '1.
|
76
|
-
- - ">="
|
77
|
-
- !ruby/object:Gem::Version
|
78
|
-
version: 1.0.2
|
75
|
+
version: '1.1'
|
79
76
|
type: :runtime
|
80
77
|
prerelease: false
|
81
78
|
version_requirements: !ruby/object:Gem::Requirement
|
82
79
|
requirements:
|
83
80
|
- - "~>"
|
84
81
|
- !ruby/object:Gem::Version
|
85
|
-
version: '1.
|
86
|
-
- - ">="
|
87
|
-
- !ruby/object:Gem::Version
|
88
|
-
version: 1.0.2
|
82
|
+
version: '1.1'
|
89
83
|
description: A ruby library for collecting prometheus metrics within forking servers
|
90
84
|
email:
|
91
85
|
- atongen@gmail.com
|
@@ -137,8 +131,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
137
131
|
- !ruby/object:Gem::Version
|
138
132
|
version: '0'
|
139
133
|
requirements: []
|
140
|
-
|
141
|
-
rubygems_version: 2.5.2
|
134
|
+
rubygems_version: 3.1.2
|
142
135
|
signing_key:
|
143
136
|
specification_version: 4
|
144
137
|
summary: A ruby library for collecting prometheus metrics within forking servers
|