sensu-plugins-mongodb-mrtrotl 1.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG.md +1 -0
- data/LICENSE +22 -0
- data/README.md +27 -0
- data/bin/check-mongodb-metric.rb +144 -0
- data/bin/check-mongodb-query-count.rb +267 -0
- data/bin/check-mongodb.py +1644 -0
- data/bin/check-mongodb.rb +5 -0
- data/bin/metrics-mongodb-replication.rb +254 -0
- data/bin/metrics-mongodb.rb +133 -0
- data/lib/bson/__init__.py +1347 -0
- data/lib/bson/__pycache__/__init__.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/_helpers.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/binary.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/code.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/codec_options.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/dbref.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/decimal128.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/errors.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/int64.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/json_util.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/max_key.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/min_key.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/objectid.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/raw_bson.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/regex.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/son.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/timestamp.cpython-310.pyc +0 -0
- data/lib/bson/__pycache__/tz_util.cpython-310.pyc +0 -0
- data/lib/bson/_cbson.cpython-310-x86_64-linux-gnu.so +0 -0
- data/lib/bson/_helpers.py +41 -0
- data/lib/bson/binary.py +364 -0
- data/lib/bson/code.py +101 -0
- data/lib/bson/codec_options.py +414 -0
- data/lib/bson/codec_options.pyi +100 -0
- data/lib/bson/dbref.py +133 -0
- data/lib/bson/decimal128.py +314 -0
- data/lib/bson/errors.py +35 -0
- data/lib/bson/int64.py +39 -0
- data/lib/bson/json_util.py +874 -0
- data/lib/bson/max_key.py +55 -0
- data/lib/bson/min_key.py +55 -0
- data/lib/bson/objectid.py +286 -0
- data/lib/bson/py.typed +2 -0
- data/lib/bson/raw_bson.py +175 -0
- data/lib/bson/regex.py +135 -0
- data/lib/bson/son.py +208 -0
- data/lib/bson/timestamp.py +124 -0
- data/lib/bson/tz_util.py +52 -0
- data/lib/gridfs/__init__.py +1015 -0
- data/lib/gridfs/__pycache__/__init__.cpython-310.pyc +0 -0
- data/lib/gridfs/__pycache__/errors.cpython-310.pyc +0 -0
- data/lib/gridfs/__pycache__/grid_file.cpython-310.pyc +0 -0
- data/lib/gridfs/errors.py +33 -0
- data/lib/gridfs/grid_file.py +907 -0
- data/lib/gridfs/py.typed +2 -0
- data/lib/pymongo/__init__.py +185 -0
- data/lib/pymongo/__pycache__/__init__.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/_csot.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/aggregation.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/auth.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/auth_aws.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/bulk.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/change_stream.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/client_options.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/client_session.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/collation.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/collection.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/command_cursor.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/common.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/compression_support.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/cursor.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/daemon.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/database.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/driver_info.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/encryption.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/encryption_options.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/errors.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/event_loggers.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/hello.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/helpers.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/max_staleness_selectors.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/message.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/mongo_client.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/monitor.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/monitoring.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/network.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/ocsp_cache.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/ocsp_support.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/operations.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/periodic_executor.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/pool.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/pyopenssl_context.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/read_concern.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/read_preferences.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/response.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/results.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/saslprep.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/server.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/server_api.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/server_description.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/server_selectors.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/server_type.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/settings.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/socket_checker.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/srv_resolver.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/ssl_context.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/ssl_support.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/topology.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/topology_description.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/typings.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/uri_parser.cpython-310.pyc +0 -0
- data/lib/pymongo/__pycache__/write_concern.cpython-310.pyc +0 -0
- data/lib/pymongo/_cmessage.cpython-310-x86_64-linux-gnu.so +0 -0
- data/lib/pymongo/_csot.py +118 -0
- data/lib/pymongo/aggregation.py +229 -0
- data/lib/pymongo/auth.py +549 -0
- data/lib/pymongo/auth_aws.py +94 -0
- data/lib/pymongo/bulk.py +513 -0
- data/lib/pymongo/change_stream.py +457 -0
- data/lib/pymongo/client_options.py +302 -0
- data/lib/pymongo/client_session.py +1112 -0
- data/lib/pymongo/collation.py +224 -0
- data/lib/pymongo/collection.py +3204 -0
- data/lib/pymongo/command_cursor.py +353 -0
- data/lib/pymongo/common.py +984 -0
- data/lib/pymongo/compression_support.py +149 -0
- data/lib/pymongo/cursor.py +1345 -0
- data/lib/pymongo/daemon.py +141 -0
- data/lib/pymongo/database.py +1202 -0
- data/lib/pymongo/driver_info.py +42 -0
- data/lib/pymongo/encryption.py +884 -0
- data/lib/pymongo/encryption_options.py +221 -0
- data/lib/pymongo/errors.py +365 -0
- data/lib/pymongo/event_loggers.py +221 -0
- data/lib/pymongo/hello.py +219 -0
- data/lib/pymongo/helpers.py +259 -0
- data/lib/pymongo/max_staleness_selectors.py +114 -0
- data/lib/pymongo/message.py +1440 -0
- data/lib/pymongo/mongo_client.py +2144 -0
- data/lib/pymongo/monitor.py +440 -0
- data/lib/pymongo/monitoring.py +1801 -0
- data/lib/pymongo/network.py +311 -0
- data/lib/pymongo/ocsp_cache.py +87 -0
- data/lib/pymongo/ocsp_support.py +372 -0
- data/lib/pymongo/operations.py +507 -0
- data/lib/pymongo/periodic_executor.py +183 -0
- data/lib/pymongo/pool.py +1660 -0
- data/lib/pymongo/py.typed +2 -0
- data/lib/pymongo/pyopenssl_context.py +383 -0
- data/lib/pymongo/read_concern.py +75 -0
- data/lib/pymongo/read_preferences.py +609 -0
- data/lib/pymongo/response.py +109 -0
- data/lib/pymongo/results.py +217 -0
- data/lib/pymongo/saslprep.py +113 -0
- data/lib/pymongo/server.py +247 -0
- data/lib/pymongo/server_api.py +170 -0
- data/lib/pymongo/server_description.py +285 -0
- data/lib/pymongo/server_selectors.py +153 -0
- data/lib/pymongo/server_type.py +32 -0
- data/lib/pymongo/settings.py +159 -0
- data/lib/pymongo/socket_checker.py +104 -0
- data/lib/pymongo/srv_resolver.py +126 -0
- data/lib/pymongo/ssl_context.py +39 -0
- data/lib/pymongo/ssl_support.py +99 -0
- data/lib/pymongo/topology.py +890 -0
- data/lib/pymongo/topology_description.py +639 -0
- data/lib/pymongo/typings.py +39 -0
- data/lib/pymongo/uri_parser.py +624 -0
- data/lib/pymongo/write_concern.py +129 -0
- data/lib/pymongo-4.2.0.dist-info/INSTALLER +1 -0
- data/lib/pymongo-4.2.0.dist-info/LICENSE +201 -0
- data/lib/pymongo-4.2.0.dist-info/METADATA +250 -0
- data/lib/pymongo-4.2.0.dist-info/RECORD +167 -0
- data/lib/pymongo-4.2.0.dist-info/REQUESTED +0 -0
- data/lib/pymongo-4.2.0.dist-info/WHEEL +6 -0
- data/lib/pymongo-4.2.0.dist-info/top_level.txt +3 -0
- data/lib/sensu-plugins-mongodb/metrics.rb +391 -0
- data/lib/sensu-plugins-mongodb/version.rb +9 -0
- data/lib/sensu-plugins-mongodb.rb +1 -0
- metadata +407 -0
@@ -0,0 +1,254 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
#
|
3
|
+
# metrics-mongodb-replication.rb
|
4
|
+
#
|
5
|
+
# DESCRIPTION:
|
6
|
+
#
|
7
|
+
# OUTPUT:
|
8
|
+
# metric data
|
9
|
+
#
|
10
|
+
# PLATFORMS:
|
11
|
+
# Linux
|
12
|
+
#
|
13
|
+
# DEPENDENCIES:
|
14
|
+
# gem: sensu-plugin
|
15
|
+
# gem: mongo
|
16
|
+
# gem: bson
|
17
|
+
# gem: bson_ext
|
18
|
+
#
|
19
|
+
# USAGE:
|
20
|
+
# #YELLOW
|
21
|
+
#
|
22
|
+
# NOTES::
|
23
|
+
# Basics from github.com/sensu-plugins/sensu-plugins-mongodb/bin/metrics-mongodb
|
24
|
+
#
|
25
|
+
# Replication lag is calculated by obtaining the last optime from primary and
|
26
|
+
# secondary members. The last optime of the secondary is subtracted from the
|
27
|
+
# last optime of the primary to produce the difference in seconds, minutes and hours
|
28
|
+
#
|
29
|
+
# LICENSE:
|
30
|
+
# Copyright 2016 Rycroft Solutions
|
31
|
+
# Released under the same terms as Sensu (the MIT license); see LICENSE
|
32
|
+
# for details.
|
33
|
+
#
|
34
|
+
|
35
|
+
require 'sensu-plugin/metric/cli'
|
36
|
+
require 'mongo'
|
37
|
+
require 'date'
|
38
|
+
include Mongo
|
39
|
+
|
40
|
+
#
|
41
|
+
# Mongodb
|
42
|
+
#
|
43
|
+
|
44
|
+
class MongoDB < Sensu::Plugin::Metric::CLI::Graphite
|
45
|
+
option :host,
|
46
|
+
description: 'MongoDB host',
|
47
|
+
long: '--host HOST',
|
48
|
+
default: 'localhost'
|
49
|
+
|
50
|
+
option :port,
|
51
|
+
description: 'MongoDB port',
|
52
|
+
long: '--port PORT',
|
53
|
+
default: 27_017
|
54
|
+
|
55
|
+
option :user,
|
56
|
+
description: 'MongoDB user',
|
57
|
+
long: '--user USER',
|
58
|
+
default: nil
|
59
|
+
|
60
|
+
option :password,
|
61
|
+
description: 'MongoDB password',
|
62
|
+
long: '--password PASSWORD',
|
63
|
+
default: nil
|
64
|
+
|
65
|
+
option :ssl,
|
66
|
+
description: 'Connect using SSL',
|
67
|
+
long: '--ssl',
|
68
|
+
default: false
|
69
|
+
|
70
|
+
option :ssl_cert,
|
71
|
+
description: 'The certificate file used to identify the local connection against mongod',
|
72
|
+
long: '--ssl-cert SSL_CERT',
|
73
|
+
default: ''
|
74
|
+
|
75
|
+
option :ssl_key,
|
76
|
+
description: 'The private key used to identify the local connection against mongod',
|
77
|
+
long: '--ssl-key SSL_KEY',
|
78
|
+
default: ''
|
79
|
+
|
80
|
+
option :ssl_ca_cert,
|
81
|
+
description: 'The set of concatenated CA certificates, which are used to validate certificates passed from the other end of the connection',
|
82
|
+
long: '--ssl-ca-cert SSL_CA_CERT',
|
83
|
+
default: ''
|
84
|
+
|
85
|
+
option :ssl_verify,
|
86
|
+
description: 'Whether or not to do peer certification validation',
|
87
|
+
long: '--ssl-verify',
|
88
|
+
default: false
|
89
|
+
|
90
|
+
option :scheme,
|
91
|
+
description: 'Metric naming scheme',
|
92
|
+
long: '--scheme SCHEME',
|
93
|
+
short: '-s SCHEME',
|
94
|
+
default: "#{Socket.gethostname}.mongodb"
|
95
|
+
|
96
|
+
option :password,
|
97
|
+
description: 'MongoDB password',
|
98
|
+
long: '--password PASSWORD',
|
99
|
+
default: nil
|
100
|
+
|
101
|
+
option :debug,
|
102
|
+
description: 'Enable debug',
|
103
|
+
long: '--debug',
|
104
|
+
default: false
|
105
|
+
|
106
|
+
def get_mongo_doc(command)
|
107
|
+
rs = @db.command(command)
|
108
|
+
unless rs.successful?
|
109
|
+
return nil
|
110
|
+
end
|
111
|
+
|
112
|
+
rs.documents[0]
|
113
|
+
end
|
114
|
+
|
115
|
+
def connect_mongo_db
|
116
|
+
address_str = "#{config[:host]}:#{config[:port]}"
|
117
|
+
client_opts = {}
|
118
|
+
client_opts[:database] = 'admin'
|
119
|
+
unless config[:user].nil?
|
120
|
+
client_opts[:user] = config[:user]
|
121
|
+
client_opts[:password] = config[:password]
|
122
|
+
end
|
123
|
+
if config[:ssl]
|
124
|
+
client_opts[:ssl] = true
|
125
|
+
client_opts[:ssl_cert] = config[:ssl_cert]
|
126
|
+
client_opts[:ssl_key] = config[:ssl_key]
|
127
|
+
client_opts[:ssl_ca_cert] = config[:ssl_ca_cert]
|
128
|
+
client_opts[:ssl_verify] = config[:ssl_verify]
|
129
|
+
end
|
130
|
+
mongo_client = Mongo::Client.new([address_str], client_opts)
|
131
|
+
@db = mongo_client.database
|
132
|
+
end
|
133
|
+
|
134
|
+
def run
|
135
|
+
Mongo::Logger.logger.level = Logger::FATAL
|
136
|
+
@debug = config[:debug]
|
137
|
+
if @debug
|
138
|
+
Mongo::Logger.logger.level = Logger::DEBUG
|
139
|
+
config_debug = config.clone
|
140
|
+
config_debug[:password] = '***'
|
141
|
+
puts 'arguments:' + config_debug.inspect
|
142
|
+
end
|
143
|
+
|
144
|
+
connect_mongo_db
|
145
|
+
|
146
|
+
_result = false
|
147
|
+
# check if master
|
148
|
+
begin
|
149
|
+
@is_master = get_mongo_doc('isMaster' => 1)
|
150
|
+
unless @is_master.nil?
|
151
|
+
_result = @is_master['ok'] == 1
|
152
|
+
end
|
153
|
+
rescue StandardError => e
|
154
|
+
if @debug
|
155
|
+
puts 'Error checking isMaster:' + e.message
|
156
|
+
puts e.backtrace.inspect
|
157
|
+
end
|
158
|
+
exit(1)
|
159
|
+
end
|
160
|
+
|
161
|
+
replication_status = get_mongo_doc('replSetGetStatus' => 1)
|
162
|
+
|
163
|
+
# get the replication metrics
|
164
|
+
begin
|
165
|
+
metrics = {}
|
166
|
+
if !replication_status.nil? && replication_status['ok'] == 1
|
167
|
+
metrics.update(gather_replication_metrics(replication_status))
|
168
|
+
timestamp = Time.now.to_i
|
169
|
+
metrics.each do |k, v|
|
170
|
+
unless v.nil?
|
171
|
+
output [config[:scheme], 'replication', k].join('.'), v, timestamp
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
rescue StandardError => e
|
176
|
+
if @debug
|
177
|
+
puts 'Error checking replicationStatus:' + e.message
|
178
|
+
puts e.backtrace.inspect
|
179
|
+
end
|
180
|
+
exit(2)
|
181
|
+
end
|
182
|
+
|
183
|
+
# Get the repllication member metrics
|
184
|
+
begin
|
185
|
+
metrics = {}
|
186
|
+
replication_members = replication_status['members']
|
187
|
+
unless replication_members.nil?
|
188
|
+
state_map = {
|
189
|
+
'PRIMARY' => 1,
|
190
|
+
'SECONDARY' => 2
|
191
|
+
}
|
192
|
+
state_map.default = 3
|
193
|
+
replication_members.sort! { |x, y| state_map[x['stateStr']] <=> state_map[y['stateStr']] }
|
194
|
+
|
195
|
+
replication_members.each do |replication_member_details|
|
196
|
+
metrics.update(gather_replication_member_metrics(replication_member_details))
|
197
|
+
member_id = replication_member_details['_id']
|
198
|
+
timestamp = Time.now.to_i
|
199
|
+
metrics.each do |k, v|
|
200
|
+
unless v.nil?
|
201
|
+
output [config[:scheme], "member_#{member_id}", k].join('.'), v, timestamp
|
202
|
+
end
|
203
|
+
end
|
204
|
+
end
|
205
|
+
end
|
206
|
+
rescue StandardError => e
|
207
|
+
if @debug
|
208
|
+
puts 'Error checking replicationMemberStatus:' + e.message
|
209
|
+
puts e.backtrace.inspect
|
210
|
+
end
|
211
|
+
exit(2)
|
212
|
+
end
|
213
|
+
|
214
|
+
# done!
|
215
|
+
ok
|
216
|
+
end
|
217
|
+
|
218
|
+
def gather_replication_metrics(replication_status)
|
219
|
+
replication_metrics = {}
|
220
|
+
|
221
|
+
replication_metrics['myState'] = replication_status['myState']
|
222
|
+
replication_metrics['term'] = replication_status['term']
|
223
|
+
replication_metrics['heartbeatIntervalMillis'] = replication_status['heartbeatIntervalMillis']
|
224
|
+
|
225
|
+
replication_metrics
|
226
|
+
end
|
227
|
+
|
228
|
+
def gather_replication_member_metrics(replication_member_details)
|
229
|
+
replication_member_metrics = {}
|
230
|
+
|
231
|
+
replication_member_metrics['id'] = replication_member_details['_id']
|
232
|
+
replication_member_metrics['health'] = replication_member_details['health']
|
233
|
+
replication_member_metrics['state'] = replication_member_details['state']
|
234
|
+
member_hierarchy = replication_member_details['stateStr']
|
235
|
+
if member_hierarchy == 'PRIMARY'
|
236
|
+
@primary_optime_date = replication_member_details['optimeDate']
|
237
|
+
end
|
238
|
+
if member_hierarchy == 'SECONDARY'
|
239
|
+
@secondary_optime_date = replication_member_details['optimeDate']
|
240
|
+
difference_in_seconds = (@primary_optime_date - @secondary_optime_date).to_i
|
241
|
+
difference_in_minutes = ((@primary_optime_date - @secondary_optime_date) / 60).to_i
|
242
|
+
difference_in_hours = ((@primary_optime_date - @secondary_optime_date) / 3600).to_i
|
243
|
+
replication_member_metrics['secondsBehindPrimary'] = difference_in_seconds
|
244
|
+
replication_member_metrics['minutesBehindPrimary'] = difference_in_minutes
|
245
|
+
replication_member_metrics['hoursBehindPrimary'] = difference_in_hours
|
246
|
+
end
|
247
|
+
replication_member_metrics['uptime'] = replication_member_details['uptime']
|
248
|
+
replication_member_metrics['lastHeartbeatRecv'] = replication_member_details['lastHeartbeatiRecv']
|
249
|
+
replication_member_metrics['pingMs'] = replication_member_details['pingMs']
|
250
|
+
replication_member_metrics['configVersion'] = replication_member_details['configVersion']
|
251
|
+
|
252
|
+
replication_member_metrics
|
253
|
+
end
|
254
|
+
end
|
@@ -0,0 +1,133 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
#
|
3
|
+
# metrics-mongodb.rb
|
4
|
+
#
|
5
|
+
# DESCRIPTION:
|
6
|
+
#
|
7
|
+
# OUTPUT:
|
8
|
+
# metric data
|
9
|
+
#
|
10
|
+
# PLATFORMS:
|
11
|
+
# Linux
|
12
|
+
#
|
13
|
+
# DEPENDENCIES:
|
14
|
+
# gem: sensu-plugin
|
15
|
+
# gem: mongo
|
16
|
+
# gem: bson
|
17
|
+
# gem: bson_ext
|
18
|
+
#
|
19
|
+
# USAGE:
|
20
|
+
# #YELLOW
|
21
|
+
#
|
22
|
+
# NOTES:
|
23
|
+
# Basics from github.com/mantree/mongodb-graphite-metrics
|
24
|
+
#
|
25
|
+
# LICENSE:
|
26
|
+
# Copyright 2013 github.com/foomatty
|
27
|
+
# Released under the same terms as Sensu (the MIT license); see LICENSE
|
28
|
+
# for details.
|
29
|
+
#
|
30
|
+
|
31
|
+
require 'sensu-plugin/metric/cli'
|
32
|
+
require 'sensu-plugins-mongodb/metrics'
|
33
|
+
require 'mongo'
|
34
|
+
include Mongo
|
35
|
+
|
36
|
+
#
|
37
|
+
# Mongodb
|
38
|
+
#
|
39
|
+
|
40
|
+
class MongoDB < Sensu::Plugin::Metric::CLI::Graphite
|
41
|
+
option :host,
|
42
|
+
description: 'MongoDB host',
|
43
|
+
long: '--host HOST',
|
44
|
+
default: 'localhost'
|
45
|
+
|
46
|
+
option :port,
|
47
|
+
description: 'MongoDB port',
|
48
|
+
long: '--port PORT',
|
49
|
+
default: 27_017
|
50
|
+
|
51
|
+
option :user,
|
52
|
+
description: 'MongoDB user',
|
53
|
+
long: '--user USER',
|
54
|
+
default: nil
|
55
|
+
|
56
|
+
option :password,
|
57
|
+
description: 'MongoDB password',
|
58
|
+
long: '--password PASSWORD',
|
59
|
+
default: nil
|
60
|
+
|
61
|
+
option :ssl,
|
62
|
+
description: 'Connect using SSL',
|
63
|
+
long: '--ssl',
|
64
|
+
default: false
|
65
|
+
|
66
|
+
option :ssl_cert,
|
67
|
+
description: 'The certificate file used to identify the local connection against mongod',
|
68
|
+
long: '--ssl-cert SSL_CERT',
|
69
|
+
default: ''
|
70
|
+
|
71
|
+
option :ssl_key,
|
72
|
+
description: 'The private key used to identify the local connection against mongod',
|
73
|
+
long: '--ssl-key SSL_KEY',
|
74
|
+
default: ''
|
75
|
+
|
76
|
+
option :ssl_ca_cert,
|
77
|
+
description: 'The set of concatenated CA certificates, which are used to validate certificates passed from the other end of the connection',
|
78
|
+
long: '--ssl-ca-cert SSL_CA_CERT',
|
79
|
+
default: ''
|
80
|
+
|
81
|
+
option :ssl_verify,
|
82
|
+
description: 'Whether or not to do peer certification validation',
|
83
|
+
long: '--ssl-verify',
|
84
|
+
default: false
|
85
|
+
|
86
|
+
option :debug,
|
87
|
+
description: 'Enable debug',
|
88
|
+
long: '--debug',
|
89
|
+
default: false
|
90
|
+
|
91
|
+
option :scheme,
|
92
|
+
description: 'Metric naming scheme',
|
93
|
+
long: '--scheme SCHEME',
|
94
|
+
short: '-s SCHEME',
|
95
|
+
default: "#{Socket.gethostname}.mongodb"
|
96
|
+
|
97
|
+
option :require_master,
|
98
|
+
description: 'Require the node to be a master node',
|
99
|
+
long: '--require-master',
|
100
|
+
default: false
|
101
|
+
|
102
|
+
option :exclude_db_sizes,
|
103
|
+
description: 'Exclude database sizes',
|
104
|
+
long: '--exclude-db-sizes',
|
105
|
+
default: false
|
106
|
+
|
107
|
+
def run
|
108
|
+
Mongo::Logger.logger.level = Logger::FATAL
|
109
|
+
@debug = config[:debug]
|
110
|
+
if @debug
|
111
|
+
Mongo::Logger.logger.level = Logger::DEBUG
|
112
|
+
config_debug = config.clone
|
113
|
+
config_debug[:password] = '***'
|
114
|
+
puts 'Arguments: ' + config_debug.inspect
|
115
|
+
end
|
116
|
+
|
117
|
+
# Get the metrics.
|
118
|
+
collector = SensuPluginsMongoDB::Metrics.new(config)
|
119
|
+
collector.connect_mongo_db('admin')
|
120
|
+
exit(1) if config[:require_master] && !collector.master?
|
121
|
+
metrics = collector.server_metrics
|
122
|
+
metrics = metrics.reject { |k, _v| k[/databaseSizes/] } if config[:exclude_db_sizes]
|
123
|
+
|
124
|
+
# Print them in graphite format.
|
125
|
+
timestamp = Time.now.to_i
|
126
|
+
metrics.each do |k, v|
|
127
|
+
output [config[:scheme], k].join('.'), v, timestamp
|
128
|
+
end
|
129
|
+
|
130
|
+
# done!
|
131
|
+
ok
|
132
|
+
end
|
133
|
+
end
|