2014-10-28 17:33:55 +01:00
#
2020-01-06 15:19:23 +01:00
# Copyright 2020 Centreon (http://www.centreon.com/)
2015-07-21 11:51:02 +02:00
#
# Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for
# service performance.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
2014-10-28 17:33:55 +01:00
package apps::vmware::connector::mode::datastoreiops ;
2019-02-04 11:01:04 +01:00
use base qw( centreon::plugins::templates::counter ) ;
2014-10-28 17:33:55 +01:00
use strict ;
use warnings ;
2019-02-04 11:01:04 +01:00
use centreon::plugins::misc ;
use centreon::plugins::templates::catalog_functions qw( catalog_status_threshold ) ;
sub custom_status_output {
my ( $ self , % options ) = @ _ ;
my $ msg = 'accessible ' . $ self - > { result_values } - > { accessible } ;
return $ msg ;
}
sub custom_status_calc {
my ( $ self , % options ) = @ _ ;
$ self - > { result_values } - > { accessible } = $ options { new_datas } - > { $ self - > { instance } . '_accessible' } ;
return 0 ;
}
sub set_counters {
my ( $ self , % options ) = @ _ ;
$ self - > { maps_counters_type } = [
{ name = > 'datastore' , type = > 3 , cb_prefix_output = > 'prefix_datastore_output' , cb_long_output = > 'datastore_long_output' , indent_long_output = > ' ' , message_multiple = > 'All datastores are ok' ,
group = > [
{ name = > 'global' , type = > 0 , skipped_code = > { - 10 = > 1 } } ,
{ name = > 'global_iops' , type = > 0 , skipped_code = > { - 10 = > 1 } } ,
{ name = > 'vm' , cb_prefix_output = > 'prefix_vm_output' , message_multiple = > 'All virtual machines IOPs are ok' , type = > 1 , skipped_code = > { - 10 = > 1 } } ,
]
}
] ;
$ self - > { maps_counters } - > { global } = [
{ label = > 'status' , threshold = > 0 , set = > {
key_values = > [ { name = > 'accessible' } ] ,
closure_custom_calc = > $ self - > can ( 'custom_status_calc' ) ,
closure_custom_output = > $ self - > can ( 'custom_status_output' ) ,
closure_custom_perfdata = > sub { return 0 ; } ,
closure_custom_threshold_check = > \ & catalog_status_threshold ,
}
} ,
] ;
$ self - > { maps_counters } - > { global_iops } = [
2019-04-16 14:19:35 +02:00
{ label = > 'read' , nlabel = > 'datastore.read.usage.iops' , set = > {
2019-02-04 11:01:04 +01:00
key_values = > [ { name = > 'read' } ] ,
output_template = > '%s read iops' ,
perfdatas = > [
{ label = > 'riops' , value = > 'read_absolute' , template = > '%s' , unit = > 'iops' ,
min = > 0 , label_extra_instance = > 1 } ,
] ,
}
} ,
2019-04-16 14:19:35 +02:00
{ label = > 'write' , nlabel = > 'datastore.write.usage.iops' , set = > {
2019-02-04 11:01:04 +01:00
key_values = > [ { name = > 'write' } ] ,
output_template = > '%s write iops' ,
perfdatas = > [
{ label = > 'wiops' , value = > 'write_absolute' , template = > '%s' , unit = > 'iops' ,
min = > 0 , max = > 'write_absolute' , label_extra_instance = > 1 } ,
] ,
}
} ,
] ;
$ self - > { maps_counters } - > { vm } = [
2019-04-16 14:19:35 +02:00
{ label = > 'read-vm' , nlabel = > 'datastore.vm.read.usage.iops' , set = > {
2019-02-04 11:01:04 +01:00
key_values = > [ { name = > 'read' } ] ,
output_template = > '%s read iops' ,
perfdatas = > [
{ label = > 'vm_riops' , value = > 'read_absolute' , template = > '%s' , unit = > 'iops' ,
min = > 0 , label_extra_instance = > 1 } ,
] ,
}
} ,
2019-04-16 14:19:35 +02:00
{ label = > 'write-vm' , nlabel = > 'datastore.vm.write.usage.iops' , set = > {
2019-02-04 11:01:04 +01:00
key_values = > [ { name = > 'write' } ] ,
output_template = > '%s write iops' ,
perfdatas = > [
{ label = > 'vm_wiops' , value = > 'write_absolute' , template = > '%s' , unit = > 'iops' ,
min = > 0 , max = > 'write_absolute' , label_extra_instance = > 1 } ,
] ,
}
} ,
] ;
}
sub prefix_datastore_output {
my ( $ self , % options ) = @ _ ;
return "Datastore '" . $ options { instance_value } - > { display } . "' : " ;
}
sub datastore_long_output {
my ( $ self , % options ) = @ _ ;
return "checking datastore '" . $ options { instance_value } - > { display } . "'" ;
}
sub prefix_vm_output {
my ( $ self , % options ) = @ _ ;
return "virtual machine '" . $ options { instance_value } - > { display } . "' " ;
}
2014-10-28 17:33:55 +01:00
sub new {
my ( $ class , % options ) = @ _ ;
my $ self = $ class - > SUPER:: new ( package = > __PACKAGE__ , % options ) ;
bless $ self , $ class ;
2019-02-04 11:01:04 +01:00
$ options { options } - > add_options ( arguments = > {
"datastore-name:s" = > { name = > 'datastore_name' } ,
"filter" = > { name = > 'filter' } ,
"scope-datacenter:s" = > { name = > 'scope_datacenter' } ,
"detail-iops-min:s" = > { name = > 'detail_iops_min' , default = > 50 } ,
"unknown-status:s" = > { name = > 'unknown_status' , default = > '%{accessible} !~ /^true|1$/i' } ,
"warning-status:s" = > { name = > 'warning_status' , default = > '' } ,
"critical-status:s" = > { name = > 'critical_status' , default = > '' } ,
} ) ;
2014-10-28 17:33:55 +01:00
return $ self ;
}
sub check_options {
my ( $ self , % options ) = @ _ ;
2019-02-04 11:01:04 +01:00
$ self - > SUPER:: check_options ( % options ) ;
2014-10-28 17:33:55 +01:00
2019-02-04 11:01:04 +01:00
$ self - > change_macros ( macros = > [ 'unknown_status' , 'warning_status' , 'critical_status' ] ) ;
2014-10-28 17:33:55 +01:00
}
2019-02-04 11:01:04 +01:00
sub manage_selection {
2014-10-28 17:33:55 +01:00
my ( $ self , % options ) = @ _ ;
2019-02-04 11:01:04 +01:00
$ self - > { datastore } = { } ;
2020-02-04 15:29:37 +01:00
my $ response = $ options { custom } - > execute (
params = > $ self - > { option_results } ,
command = > 'datastoreiops'
) ;
2019-02-04 11:01:04 +01:00
if ( $ response - > { code } == 200 ) {
2020-02-04 15:29:37 +01:00
$ self - > { output } - > output_add (
severity = > 'OK' ,
short_msg = > $ response - > { short_message }
) ;
2020-02-04 15:34:45 +01:00
$ self - > { output } - > display ( ) ;
$ self - > { output } - > exit ( ) ;
2019-02-04 11:01:04 +01:00
}
foreach my $ ds_id ( keys % { $ response - > { data } } ) {
my $ ds_name = $ response - > { data } - > { $ ds_id } - > { name } ;
$ self - > { datastore } - > { $ ds_name } = { display = > $ ds_name ,
vm = > { } ,
global = > {
accessible = > $ response - > { data } - > { $ ds_id } - > { accessible } ,
} ,
global_iops = > {
write = > $ response - > { data } - > { $ ds_id } - > { 'disk.numberWrite.summation' } ,
read = > $ response - > { data } - > { $ ds_id } - > { 'disk.numberRead.summation' } ,
} ,
} ;
foreach my $ vm_name ( sort keys % { $ response - > { data } - > { $ ds_id } - > { vm } } ) {
$ self - > { datastore } - > { $ ds_name } - > { vm } - > { $ vm_name } = {
display = > $ vm_name ,
write = > $ response - > { data } - > { $ ds_id } - > { vm } - > { $ vm_name } - > { 'disk.numberWrite.summation' } ,
read = > $ response - > { data } - > { $ ds_id } - > { vm } - > { $ vm_name } - > { 'disk.numberRead.summation' } ,
} ;
}
}
2014-10-28 17:33:55 +01:00
}
1 ;
__END__
= head1 MODE
Check datastore IOPs .
= over 8
= item B <--datastore-name>
datastore name to list .
= item B <--filter>
Datastore name is a regexp .
2015-04-28 11:14:48 +02:00
= item B <--scope-datacenter>
Search in following datacenter ( s ) ( can be a regexp ) .
2014-10-28 17:33:55 +01:00
= item B <--detail-iops-min>
Only display VMs with iops higher value ( default: 50 ) .
2019-02-04 11:01:04 +01:00
= item B <--unknown-status>
Set warning threshold for status ( Default: '%{accessible} !~ /^true|1$/i' ) .
2019-02-06 10:16:58 +01:00
Can used special variables like: % { accessible }
2019-02-04 11:01:04 +01:00
= item B <--warning-status>
Set warning threshold for status ( Default: '' ) .
2019-02-06 10:16:58 +01:00
Can used special variables like: % { accessible }
2019-02-04 11:01:04 +01:00
= item B <--critical-status>
Set critical threshold for status ( Default: '' ) .
2019-02-06 10:16:58 +01:00
Can used special variables like: % { accessible }
2019-02-04 11:01:04 +01:00
= item B <--warning-*>
2014-10-28 17:33:55 +01:00
2019-02-04 11:01:04 +01:00
Threshold warning .
2019-02-04 11:30:30 +01:00
Can be: 'read' , 'write' , 'read-vm' , 'write-vm' .
2014-10-28 17:33:55 +01:00
2019-02-04 11:01:04 +01:00
= item B <--critical-*>
2014-10-28 17:33:55 +01:00
2019-02-04 11:01:04 +01:00
Threshold critical .
2019-02-04 11:30:30 +01:00
Can be: 'read' , 'write' , 'read-vm' , 'write-vm' .
2014-10-28 17:33:55 +01:00
= back
= cut