netuitived 0.9.4 → 0.9.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/netuitived +16 -1
- data/lib/netuitive/metric_aggregator.rb +20 -0
- data/lib/netuitive/netuitived_logger.rb +10 -9
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ac2b7bfed2a40b9ec18f5420fd39223e6a7afe48
|
4
|
+
data.tar.gz: 7952f0f92d29b854eb2a63b84836bae082d8c53a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 207c210cc103b5f149ebb770c82ddacbaa317b60c63aa84f3c934a348a3e69571ea9bcb6ce60692f776bc36e1009c94c9265c37dd397297d4f9c7e28d7ff3b35
|
7
|
+
data.tar.gz: 81477f558acdd8395dc5ae62e5ce85fc1469c3fb19d7e800e7a38ac6908c04919c60f5fbcae4477f3d0ff198a5d391d57fcf6d5da5a038daf9d96056f91088c6
|
data/bin/netuitived
CHANGED
@@ -27,6 +27,17 @@ if ARGV[0] == "start"
|
|
27
27
|
if written
|
28
28
|
File.open("#{gem_root}/config/agent.yml", 'w') {|f| f.write data.to_yaml }
|
29
29
|
end
|
30
|
+
require 'drb/drb'
|
31
|
+
netuitivedAddr=data["netuitivedAddr"]
|
32
|
+
netuitivedPort=data["netuitivedPort"]
|
33
|
+
SERVER_URI="druby://#{netuitivedAddr}:#{netuitivedPort}"
|
34
|
+
DRb.start_service
|
35
|
+
begin
|
36
|
+
DRbObject.new_with_uri(SERVER_URI).stopServer
|
37
|
+
sleep(2)
|
38
|
+
rescue
|
39
|
+
|
40
|
+
end
|
30
41
|
require 'netuitived'
|
31
42
|
elsif ARGV[0] == "stop"
|
32
43
|
require 'drb/drb'
|
@@ -34,7 +45,11 @@ elsif ARGV[0] == "stop"
|
|
34
45
|
netuitivedPort=data["netuitivedPort"]
|
35
46
|
SERVER_URI="druby://#{netuitivedAddr}:#{netuitivedPort}"
|
36
47
|
DRb.start_service
|
37
|
-
|
48
|
+
begin
|
49
|
+
DRbObject.new_with_uri(SERVER_URI).stopServer
|
50
|
+
rescue
|
51
|
+
puts "netuitived isn't running"
|
52
|
+
end
|
38
53
|
else
|
39
54
|
puts "invalid option. options are: start, stop"
|
40
55
|
end
|
@@ -52,6 +52,14 @@ class MetricAggregator
|
|
52
52
|
NetuitiveLogger.log.debug "aggregatedSamples id: #{@aggregatedSamples.object_id}"
|
53
53
|
NetuitiveLogger.log.debug "metrics before add: #{@metrics.count}"
|
54
54
|
NetuitiveLogger.log.debug "samples before add: #{@aggregatedSamples.count + @samples.count}"
|
55
|
+
if metricId == nil
|
56
|
+
NetuitiveLogger.log.info "null metricId for addSample"
|
57
|
+
return false
|
58
|
+
end
|
59
|
+
if val == nil
|
60
|
+
NetuitiveLogger.log.info "null value for addSample for metricId #{metricId}"
|
61
|
+
return false
|
62
|
+
end
|
55
63
|
if not metricExists metricId
|
56
64
|
NetuitiveLogger.log.info "adding new metric: #{metricId}"
|
57
65
|
@metrics.push(IngestMetric.new(metricId, metricId, nil, "custom", nil, false))
|
@@ -83,11 +91,23 @@ class MetricAggregator
|
|
83
91
|
NetuitiveLogger.log.debug "aggregatedSamples id: #{@aggregatedSamples.object_id}"
|
84
92
|
NetuitiveLogger.log.debug "metrics before aggregate: #{@metrics.count}"
|
85
93
|
NetuitiveLogger.log.debug "samples before aggregate: #{@aggregatedSamples.count + @samples.count}"
|
94
|
+
if metricId == nil
|
95
|
+
NetuitiveLogger.log.info "null metricId for aggregateMetric"
|
96
|
+
return false
|
97
|
+
end
|
98
|
+
if val == nil
|
99
|
+
NetuitiveLogger.log.info "null value for aggregateMetric for metricId #{metricId}"
|
100
|
+
return false
|
101
|
+
end
|
86
102
|
if not metricExists metricId
|
87
103
|
NetuitiveLogger.log.info "adding new metric: #{metricId}"
|
88
104
|
@metrics.push(IngestMetric.new(metricId, metricId, nil, "custom", nil, false))
|
89
105
|
@aggregatedSamples["#{metricId}"]=IngestSample.new(metricId, Time.new, val, nil, nil, nil, nil, nil)
|
90
106
|
else
|
107
|
+
if @aggregatedSamples["#{metricId}"] == nil
|
108
|
+
NetuitiveLogger.log.info "cannot aggregate metric #{metricId} that already has samples for this interval"
|
109
|
+
return false
|
110
|
+
end
|
91
111
|
previousVal = @aggregatedSamples["#{metricId}"].val
|
92
112
|
@aggregatedSamples["#{metricId}"].val+=val
|
93
113
|
NetuitiveLogger.log.info "netuitive sample aggregated #{metricId} old val: #{previousVal} new val: #{@aggregatedSamples["#{metricId}"].val}"
|
@@ -1,4 +1,14 @@
|
|
1
1
|
require 'logger'
|
2
|
+
class CheaterLogger
|
3
|
+
attr_accessor :level
|
4
|
+
def debug(message)
|
5
|
+
end
|
6
|
+
def error(message)
|
7
|
+
end
|
8
|
+
def info(message)
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
2
12
|
class NetuitiveLogger
|
3
13
|
begin
|
4
14
|
@@log = Logger.new("#{File.expand_path("../../..", __FILE__)}/log/netuitive.log",'daily', 10)
|
@@ -11,13 +21,4 @@ class NetuitiveLogger
|
|
11
21
|
return @@log
|
12
22
|
end
|
13
23
|
end
|
14
|
-
end
|
15
|
-
|
16
|
-
class CheaterLogger
|
17
|
-
def debug(message)
|
18
|
-
end
|
19
|
-
def error(message)
|
20
|
-
end
|
21
|
-
def info(message)
|
22
|
-
end
|
23
24
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: netuitived
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.9.
|
4
|
+
version: 0.9.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- John King
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-11-
|
11
|
+
date: 2015-11-20 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: Collects metrics over a certain interval and then sends them to Netuitive
|
14
14
|
email: jking@netuitive.com
|