sensu-plugins-hbase 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 596f24880b29c39f05bfefc22506d48a398e6ea7
4
+ data.tar.gz: 9ec455e06ff713fd0083a0dd388ea5268717bfa5
5
+ SHA512:
6
+ metadata.gz: 96319fa33b0fbb123830851ec62f1539f573805322123483bd84059e351a8bbe469add39b0a1ec69df513e97aef635779cc92e20c5c73c671f191e46210322c9
7
+ data.tar.gz: 06823faf543cfb17245a5499936de34a515013aec4019aa5764458372e2f4e2e472b7b5686b07cf7a55054a6b8ae604b14b0de84b2bd612a5502efb9c25cdff7
checksums.yaml.gz.sig ADDED
Binary file
data.tar.gz.sig ADDED
Binary file
data/CHANGELOG.md ADDED
@@ -0,0 +1,11 @@
1
+ #Change Log
2
+ This project adheres to [Semantic Versioning](http://semver.org/).
3
+
4
+ This CHANGELOG follows the format listed at [Keep A Changelog](http://keepachangelog.com/)
5
+
6
+ ## Unreleased][unreleased]
7
+
8
+ ## [0.0.1] - 2015-06-11
9
+
10
+ ### Added
11
+ - initial release
data/LICENSE ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2015 Sensu-Plugins
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,24 @@
1
+ ## Sensu-Plugins-hbase
2
+
3
+ [![Build Status](https://travis-ci.org/sensu-plugins/sensu-plugins-hbase.svg?branch=master)](https://travis-ci.org/sensu-plugins/sensu-plugins-hbase)
4
+ [![Gem Version](https://badge.fury.io/rb/sensu-plugins-hbase.svg)](http://badge.fury.io/rb/sensu-plugins-hbase)
5
+ [![Code Climate](https://codeclimate.com/github/sensu-plugins/sensu-plugins-hbase/badges/gpa.svg)](https://codeclimate.com/github/sensu-plugins/sensu-plugins-hbase)
6
+ [![Test Coverage](https://codeclimate.com/github/sensu-plugins/sensu-plugins-hbase/badges/coverage.svg)](https://codeclimate.com/github/sensu-plugins/sensu-plugins-hbase)
7
+ [![Dependency Status](https://gemnasium.com/sensu-plugins/sensu-plugins-hbase.svg)](https://gemnasium.com/sensu-plugins/sensu-plugins-hbase)
8
+ [![Codeship Status for sensu-plugins/sensu-plugins-hbase](https://codeship.com/projects/87326720-ea2a-0132-ffd2-32dfa18a9fce/status?branch=master)](https://codeship.com/projects/83049)
9
+
10
+ ## Functionality
11
+
12
+ ## Files
13
+ * bin/check-hbase-regions.rb
14
+ * bin/check-hbase-status.rb
15
+
16
+ ## Usage
17
+
18
+ ## Installation
19
+
20
+ [Installation and Setup](https://github.com/sensu-plugins/documentation/blob/master/user_docs/installation_instructions.md)
21
+
22
+ ## Notes
23
+
24
+ This repo must remain 1.8 syntax compliant due to issues with hbase and JRuby
@@ -0,0 +1,122 @@
1
+ #!/usr/bin/hbase org.jruby.Main
2
+ #
3
+ # check-hbase-regions
4
+ #
5
+ # DESCRIPTION:
6
+ # This plugin checks the number of regions on a regionserver
7
+ #
8
+ # OUTPUT:
9
+ # plain text
10
+ #
11
+ # PLATFORMS:
12
+ # Linux with jruby
13
+ #
14
+ # USAGE:
15
+ # #YELLOW
16
+ #
17
+ # NOTES:
18
+ # #YELLOW
19
+ # rewite to use sensu-plugin
20
+ #
21
+ # LICENSE:
22
+ # Copyright 2011 Runa Inc
23
+ # Released under the same terms as Sensu (the MIT license); see LICENSE
24
+ # for details.
25
+ #
26
+ require 'java'
27
+ require 'pp'
28
+
29
+ include Java
30
+ include_class('java.lang.Integer') { |_package, name| "J#{name}" }
31
+ include_class('java.lang.Long') { |_package, name| "J#{name}" }
32
+ include_class('java.lang.Boolean') { |_package, name| "J#{name}" }
33
+
34
+ import org.apache.hadoop.hbase.client.HBaseAdmin
35
+ import org.apache.hadoop.hbase.client.HTable
36
+ import org.apache.hadoop.hbase.HBaseConfiguration
37
+ import org.apache.hadoop.hbase.util.Bytes
38
+ import org.apache.log4j.Logger
39
+
40
+ packages = ['org.apache.zookeeper', 'org.apache.hadoop', 'org.apache.hadoop.hbase']
41
+
42
+ packages.each do |package|
43
+ logger = org.apache.log4j.Logger.getLogger(package)
44
+ logger.setLevel(org.apache.log4j.Level::ERROR)
45
+ end
46
+
47
+ module SensuUtils
48
+ # Copied from sensu-plugin
49
+
50
+ EXIT_CODES = {
51
+ 'OK' => 0,
52
+ 'WARNING' => 1,
53
+ 'CRITICAL' => 2,
54
+ 'UNKNOWN' => 3
55
+ }
56
+
57
+ def output(fn, *args)
58
+ puts "#{fn.upcase}: #{args}"
59
+ end
60
+
61
+ EXIT_CODES.each do |status, code|
62
+ define_method(status.downcase) do |*args|
63
+ output(status, *args)
64
+ exit(code)
65
+ end
66
+ end
67
+ end
68
+
69
+ include SensuUtils
70
+
71
+ def regionserver_info
72
+ conf = HBaseConfiguration.new
73
+ admin = HBaseAdmin.new(conf)
74
+
75
+ status = admin.getClusterStatus
76
+ status.getServerInfo.map do |server|
77
+ {
78
+ :hostname => server.getServerAddress.getHostname,
79
+ :regions => server.getLoad.getNumberOfRegions
80
+ }
81
+ end
82
+ end
83
+
84
+ def check_threshold(info)
85
+ case info[:regions]
86
+ when config[:ok]..config[:warning]
87
+ { :status => :ok, :msg => "Regions: #{info.inspect}" }
88
+ when config[:warning]..config[:critical]
89
+ { :status => :warning, :msg => "Regions: #{info.inspect}" }
90
+ else
91
+ { :status => :critical, :msg => "Regions: #{info.inspect}" }
92
+ end
93
+ end
94
+
95
+ @config = { :ok => 0, :warning => 900, :critical => 1000 }
96
+
97
+ class Array
98
+ def second
99
+ self[1]
100
+ end
101
+ end
102
+
103
+ attr_reader :config
104
+
105
+ def run
106
+ status = regionserver_info.map { |x| check_threshold(x) }
107
+
108
+ msg = "\n" + status.map { |x| x[:msg] }.join("\n")
109
+
110
+ if status.any? { |x| x[:status] == :critical }
111
+ critical msg
112
+ elsif status.any? { |x| x[:status] == :warning }
113
+ warning msg
114
+ else
115
+ ok msg
116
+ end
117
+ end
118
+
119
+ @config[:warning] = ARGV.first.to_i if ARGV.first
120
+ @config[:critical] = ARGV.second.to_i if ARGV.second
121
+
122
+ run
@@ -0,0 +1,90 @@
1
+ #!/usr/bin/hbase org.jruby.Main
2
+ #
3
+ # check-hbase-status
4
+ #
5
+ # DESCRIPTION:
6
+ # This plugin checks the status
7
+ #
8
+ # OUTPUT:
9
+ # plain text
10
+ #
11
+ # PLATFORMS:
12
+ # Linux with jruby
13
+ #
14
+ # USAGE:
15
+ # #YELLOW
16
+ #
17
+ # NOTES:
18
+ # #YELLOW
19
+ # rewite to use sensu-plugin
20
+ #
21
+ # LICENSE:
22
+ # Copyright 2011 Runa Inc
23
+ # Released under the same terms as Sensu (the MIT license); see LICENSE
24
+ # for details.
25
+ #
26
+
27
+ require 'java'
28
+ require 'pp'
29
+
30
+ include Java
31
+ include_class('java.lang.Integer') { |_package, name| "J#{name}" }
32
+ include_class('java.lang.Long') { |_package, name| "J#{name}" }
33
+ include_class('java.lang.Boolean') { |_package, name| "J#{name}" }
34
+
35
+ import org.apache.hadoop.hbase.client.HBaseAdmin
36
+ import org.apache.hadoop.hbase.client.HTable
37
+ import org.apache.hadoop.hbase.HBaseConfiguration
38
+ import org.apache.hadoop.hbase.util.Bytes
39
+ import org.apache.log4j.Logger
40
+
41
+ packages = ['org.apache.zookeeper', 'org.apache.hadoop', 'org.apache.hadoop.hbase']
42
+
43
+ packages.each do |package|
44
+ logger = org.apache.log4j.Logger.getLogger(package)
45
+ logger.setLevel(org.apache.log4j.Level::ERROR)
46
+ end
47
+
48
+ module SensuUtils
49
+ # Copied from sensu-plugin
50
+
51
+ EXIT_CODES = {
52
+ 'OK' => 0,
53
+ 'WARNING' => 1,
54
+ 'CRITICAL' => 2,
55
+ 'UNKNOWN' => 3
56
+ }
57
+
58
+ def output(fn, *args)
59
+ puts "#{fn.upcase}: #{args}"
60
+ end
61
+
62
+ EXIT_CODES.each do |status, code|
63
+ define_method(status.downcase) do |*args|
64
+ output(status, *args)
65
+ exit(code)
66
+ end
67
+ end
68
+ end
69
+
70
+ include SensuUtils
71
+
72
+ def check_hbase_status
73
+ conf = HBaseConfiguration.new
74
+ admin = HBaseAdmin.new(conf)
75
+
76
+ status = admin.getClusterStatus
77
+ dead_servers = status.getDeadServerNames
78
+
79
+ count = dead_servers.length
80
+
81
+ if count == 0
82
+ ok 'Alive'
83
+ else
84
+ critical "Dead: #{dead_servers.join(' ')}"
85
+ end
86
+
87
+ unknown 'No output from plugin'
88
+ end
89
+
90
+ check_hbase_status
@@ -0,0 +1 @@
1
+ require 'sensu-plugins-hbase/version'
@@ -0,0 +1,9 @@
1
+ module SensuPluginsHbase
2
+ module Version
3
+ MAJOR = 0
4
+ MINOR = 0
5
+ PATCH = 1
6
+
7
+ VER_STRING = [MAJOR, MINOR, PATCH].compact.join('.')
8
+ end
9
+ end
metadata ADDED
@@ -0,0 +1,220 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sensu-plugins-hbase
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Sensu-Plugins and contributors
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain:
11
+ - |
12
+ -----BEGIN CERTIFICATE-----
13
+ MIIDgDCCAmigAwIBAgIBATANBgkqhkiG9w0BAQUFADBDMRIwEAYDVQQDDAltYXR0
14
+ am9uZXMxGDAWBgoJkiaJk/IsZAEZFgh5aWVsZGJvdDETMBEGCgmSJomT8ixkARkW
15
+ A2NvbTAeFw0xNTAxMjgyMTAyNTFaFw0xNjAxMjgyMTAyNTFaMEMxEjAQBgNVBAMM
16
+ CW1hdHRqb25lczEYMBYGCgmSJomT8ixkARkWCHlpZWxkYm90MRMwEQYKCZImiZPy
17
+ LGQBGRYDY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAyTSzVYnO
18
+ CLgyrIyT1mBQakArQyW8xhi6MlDqyzXHJGeERT790U6EgoBVeS4XoK0ptFZNR8Tf
19
+ zko0w+Nv47TarSCgkPOaxY+mxWnAVR10dOmfeLr7huiMyps+YD56/EF2FqQ3jf/+
20
+ qohENfKD91qy1ieEy+Fn7Pf74ltbNKUdkb9a9eFXQ0DQ4ip5vik7DzjQkUTj4lca
21
+ k6ArwnmHX4YDhZoYtrQJ8jVktN0/+NtA40M5qkCYHNe5tUW25b/tKVYuioxG6b2Z
22
+ oIzaZxRLxf6HVAWpCVRT/F5+/yjigkX4u++eYacfLGleXQzoK7BL65vHGMJygWEE
23
+ 0TKGqFOrl/L0AQIDAQABo38wfTAJBgNVHRMEAjAAMAsGA1UdDwQEAwIEsDAdBgNV
24
+ HQ4EFgQUEf6a8Td7MrSZc8ImbLFZAENPbz0wIQYDVR0RBBowGIEWbWF0dGpvbmVz
25
+ QHlpZWxkYm90LmNvbTAhBgNVHRIEGjAYgRZtYXR0am9uZXNAeWllbGRib3QuY29t
26
+ MA0GCSqGSIb3DQEBBQUAA4IBAQBbzXAYA3BVGw8DZ0YYoY1VHPNEcH5qPIApmHO8
27
+ rvSmuUT0yMEi7u00H/5uHRFf4LleGT/+sTdyXKsNPGT9kdRuQEgwi+vf7Zfvd8aX
28
+ UF/+4VkEYf/8rV8Ere6u2QaWPgApdMV6JjKr1fAwCTd8AuGXNaWItiPPMseSQzLJ
29
+ JKP4hVvbc1d+oS925B1lcBiqn2aYvElbyNAVmQPywNNqkWmvtlqj9ZVJfV5HQLdu
30
+ 8sHuVruarogxxKPBzlL2is4EUb6oN/RdpGx2l4254+nyR+abg//Ed27Ym0PkB4lk
31
+ HP0m8WSjZmFr109pE/sVsM5jtOCvogyujQOjNVGN4gz1wwPr
32
+ -----END CERTIFICATE-----
33
+ date: 2015-06-12 00:00:00.000000000 Z
34
+ dependencies:
35
+ - !ruby/object:Gem::Dependency
36
+ name: sensu-plugin
37
+ requirement: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - '='
40
+ - !ruby/object:Gem::Version
41
+ version: 1.1.0
42
+ type: :runtime
43
+ prerelease: false
44
+ version_requirements: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - '='
47
+ - !ruby/object:Gem::Version
48
+ version: 1.1.0
49
+ - !ruby/object:Gem::Dependency
50
+ name: bundler
51
+ requirement: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - "~>"
54
+ - !ruby/object:Gem::Version
55
+ version: '1.7'
56
+ type: :development
57
+ prerelease: false
58
+ version_requirements: !ruby/object:Gem::Requirement
59
+ requirements:
60
+ - - "~>"
61
+ - !ruby/object:Gem::Version
62
+ version: '1.7'
63
+ - !ruby/object:Gem::Dependency
64
+ name: codeclimate-test-reporter
65
+ requirement: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - "~>"
68
+ - !ruby/object:Gem::Version
69
+ version: '0.4'
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ requirements:
74
+ - - "~>"
75
+ - !ruby/object:Gem::Version
76
+ version: '0.4'
77
+ - !ruby/object:Gem::Dependency
78
+ name: github-markup
79
+ requirement: !ruby/object:Gem::Requirement
80
+ requirements:
81
+ - - "~>"
82
+ - !ruby/object:Gem::Version
83
+ version: '1.3'
84
+ type: :development
85
+ prerelease: false
86
+ version_requirements: !ruby/object:Gem::Requirement
87
+ requirements:
88
+ - - "~>"
89
+ - !ruby/object:Gem::Version
90
+ version: '1.3'
91
+ - !ruby/object:Gem::Dependency
92
+ name: pry
93
+ requirement: !ruby/object:Gem::Requirement
94
+ requirements:
95
+ - - "~>"
96
+ - !ruby/object:Gem::Version
97
+ version: '0.10'
98
+ type: :development
99
+ prerelease: false
100
+ version_requirements: !ruby/object:Gem::Requirement
101
+ requirements:
102
+ - - "~>"
103
+ - !ruby/object:Gem::Version
104
+ version: '0.10'
105
+ - !ruby/object:Gem::Dependency
106
+ name: rubocop
107
+ requirement: !ruby/object:Gem::Requirement
108
+ requirements:
109
+ - - '='
110
+ - !ruby/object:Gem::Version
111
+ version: '0.30'
112
+ type: :development
113
+ prerelease: false
114
+ version_requirements: !ruby/object:Gem::Requirement
115
+ requirements:
116
+ - - '='
117
+ - !ruby/object:Gem::Version
118
+ version: '0.30'
119
+ - !ruby/object:Gem::Dependency
120
+ name: rspec
121
+ requirement: !ruby/object:Gem::Requirement
122
+ requirements:
123
+ - - "~>"
124
+ - !ruby/object:Gem::Version
125
+ version: '3.1'
126
+ type: :development
127
+ prerelease: false
128
+ version_requirements: !ruby/object:Gem::Requirement
129
+ requirements:
130
+ - - "~>"
131
+ - !ruby/object:Gem::Version
132
+ version: '3.1'
133
+ - !ruby/object:Gem::Dependency
134
+ name: rake
135
+ requirement: !ruby/object:Gem::Requirement
136
+ requirements:
137
+ - - "~>"
138
+ - !ruby/object:Gem::Version
139
+ version: '10.0'
140
+ type: :development
141
+ prerelease: false
142
+ version_requirements: !ruby/object:Gem::Requirement
143
+ requirements:
144
+ - - "~>"
145
+ - !ruby/object:Gem::Version
146
+ version: '10.0'
147
+ - !ruby/object:Gem::Dependency
148
+ name: redcarpet
149
+ requirement: !ruby/object:Gem::Requirement
150
+ requirements:
151
+ - - "~>"
152
+ - !ruby/object:Gem::Version
153
+ version: '3.2'
154
+ type: :development
155
+ prerelease: false
156
+ version_requirements: !ruby/object:Gem::Requirement
157
+ requirements:
158
+ - - "~>"
159
+ - !ruby/object:Gem::Version
160
+ version: '3.2'
161
+ - !ruby/object:Gem::Dependency
162
+ name: yard
163
+ requirement: !ruby/object:Gem::Requirement
164
+ requirements:
165
+ - - "~>"
166
+ - !ruby/object:Gem::Version
167
+ version: '0.8'
168
+ type: :development
169
+ prerelease: false
170
+ version_requirements: !ruby/object:Gem::Requirement
171
+ requirements:
172
+ - - "~>"
173
+ - !ruby/object:Gem::Version
174
+ version: '0.8'
175
+ description: Sensu hbase plugins
176
+ email: "<sensu-users@googlegroups.com>"
177
+ executables:
178
+ - check-hbase-status.rb
179
+ - check-hbase-regions.rb
180
+ extensions: []
181
+ extra_rdoc_files: []
182
+ files:
183
+ - CHANGELOG.md
184
+ - LICENSE
185
+ - README.md
186
+ - bin/check-hbase-regions.rb
187
+ - bin/check-hbase-status.rb
188
+ - lib/sensu-plugins-hbase.rb
189
+ - lib/sensu-plugins-hbase/version.rb
190
+ homepage: https://github.com/sensu-plugins/sensu-plugins-hbase
191
+ licenses:
192
+ - MIT
193
+ metadata:
194
+ maintainer: sensu-plugin
195
+ development_status: active
196
+ production_status: unstable - testing recommended
197
+ release_draft: 'false'
198
+ release_prerelease: 'false'
199
+ post_install_message: You can use the embedded Ruby by setting EMBEDDED_RUBY=true
200
+ in /etc/default/sensu
201
+ rdoc_options: []
202
+ require_paths:
203
+ - lib
204
+ required_ruby_version: !ruby/object:Gem::Requirement
205
+ requirements:
206
+ - - ">="
207
+ - !ruby/object:Gem::Version
208
+ version: 1.9.3
209
+ required_rubygems_version: !ruby/object:Gem::Requirement
210
+ requirements:
211
+ - - ">="
212
+ - !ruby/object:Gem::Version
213
+ version: '0'
214
+ requirements: []
215
+ rubyforge_project:
216
+ rubygems_version: 2.4.6
217
+ signing_key:
218
+ specification_version: 4
219
+ summary: Sensu plugins for hbase
220
+ test_files: []
metadata.gz.sig ADDED
Binary file