From 68ec870a42791ce29865933c2894e95761036ec6 Mon Sep 17 00:00:00 2001 From: Kevin Duret Date: Tue, 18 Feb 2014 13:59:48 +0000 Subject: [PATCH] Add physical disk component #5151 --- .../dell/openmanage/mode/components/memory.pm | 2 +- .../mode/components/physicaldisk.pm | 124 ++++++++++++++++++ .../server/dell/openmanage/mode/hardware.pm | 4 + 3 files changed, 129 insertions(+), 1 deletion(-) create mode 100644 hardware/server/dell/openmanage/mode/components/physicaldisk.pm diff --git a/hardware/server/dell/openmanage/mode/components/memory.pm b/hardware/server/dell/openmanage/mode/components/memory.pm index 19524ee68..945cab8ee 100644 --- a/hardware/server/dell/openmanage/mode/components/memory.pm +++ b/hardware/server/dell/openmanage/mode/components/memory.pm @@ -89,7 +89,7 @@ sub check { my $memory_deviceFailureModes = $result2->{$oid_memoryDeviceFailureModes . '.' . $instance}; $self->{components}->{memory}->{total}++; - $self->{output}->output_add(long_msg => sprintf("memory module %d status is %s, failure mode is %s, size is %d Ko [chassis: %d, Location: %s].", + $self->{output}->output_add(long_msg => sprintf("memory module %d status is %s, failure mode is %s, size is %d KB [chassis: %d, Location: %s].", $memory_Index, ${$status{$memory_deviceStatus}}[0], $failureModes{$memory_deviceFailureModes}, $memory_deviceSize, $chassis_Index, $memory_deviceLocationName )); diff --git a/hardware/server/dell/openmanage/mode/components/physicaldisk.pm b/hardware/server/dell/openmanage/mode/components/physicaldisk.pm new file mode 100644 index 000000000..bfddeed90 --- /dev/null +++ b/hardware/server/dell/openmanage/mode/components/physicaldisk.pm @@ -0,0 +1,124 @@ +################################################################################ +# Copyright 2005-2013 MERETHIS +# Centreon is developped by : Julien Mathis and Romain Le Merlus under +# GPL Licence 2.0. +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation ; either version 2 of the License. +# +# This program is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along with +# this program; if not, see . +# +# Linking this program statically or dynamically with other modules is making a +# combined work based on this program. Thus, the terms and conditions of the GNU +# General Public License cover the whole combination. +# +# As a special exception, the copyright holders of this program give MERETHIS +# permission to link this program with independent modules to produce an executable, +# regardless of the license terms of these independent modules, and to copy and +# distribute the resulting executable under terms of MERETHIS choice, provided that +# MERETHIS also meet, for each linked independent module, the terms and conditions +# of the license of that module. An independent module is a module which is not +# derived from this program. If you modify this program, you may extend this +# exception to your version of the program, but you are not obliged to do so. If you +# do not wish to do so, delete this exception statement from your version. +# +# For more information : contact@centreon.com +# Authors : Quentin Garnier +# +#################################################################################### + +package hardware::server::dell::openmanage::mode::components::physicaldisk; + +use strict; +use warnings; + +my %state = ( + 0 => 'unknown', + 1 => 'ready', + 2 => 'failed', + 3 => 'online', + 4 => 'offline', + 6 => 'degraded', + 7 => 'recovering', + 11 => 'removed', + 15 => 'resynching', + 24 => 'rebuild', + 25 => 'noMedia', + 26 => 'formatting', + 28 => 'diagnostics', + 35 => 'initializing', +); + +my %spareState = ( + 1 => 'memberVD', + 2 => 'memberDG', + 3 => 'globalHostSpare', + 4 => 'dedicatedHostSpare', + 5 => 'notASpare', +); + +my %componentStatus = ( + 1 => ['other', 'UNKNOWN'], + 2 => ['unknown', 'UNKNOWN'], + 3 => ['ok', 'OK'], + 4 => ['nonCritical', 'WARNING'], + 5 => ['critical', 'CRITICAL'], + 6 => ['nonRecoverable', 'CRITICAL'], +); + +sub check { + my ($self) = @_; + + # In MIB '10893.mib' + $self->{output}->output_add(long_msg => "Checking Physical Disks"); + $self->{components}->{physicaldisk} = {name => 'physical disks', total => 0}; + return if ($self->check_exclude('physicaldisk')); + + my $oid_diskName = '.1.3.6.1.4.1.674.10893.1.20.130.4.1.2'; + my $oid_diskState = '.1.3.6.1.4.1.674.10893.1.20.130.4.1.4'; + my $oid_diskLengthInMB = '.1.3.6.1.4.1.674.10893.1.20.130.4.1.11'; + my $oid_diskSpareState = '.1.3.6.1.4.1.674.10893.1.20.130.4.1.22'; + my $oid_diskComponentStatus = '.1.3.6.1.4.1.674.10893.1.20.130.4.1.24'; + + my $result = $self->{snmp}->get_table(oid => $oid_diskName); + return if (scalar(keys %$result) <= 0); + + $self->{snmp}->load(oids => [$oid_diskState, $oid_diskLengthInMB, $oid_diskSpareState, $oid_diskComponentStatus], + instances => [keys %$result], + instance_regexp => '(\d+\.\d+)$'); + my $result2 = $self->{snmp}->get_leef(); + return if (scalar(keys %$result2) <= 0); + + foreach my $key ($self->{snmp}->oid_lex_sort(keys %$result)) { + $key =~ /(\d+)\.(\d+)$/; + my ($chassis_Index, $disk_Index) = ($1, $2); + my $instance = $chassis_Index . '.' . $disk_Index; + + my $disk_Name = $result->{$key}; + my $disk_State = $result2->{$oid_diskState . '.' . $instance}; + my $disk_LengthInMB = $result2->{$oid_diskLengthInMB . '.' . $instance}; + my $disk_SpareState = $result2->{$oid_diskSpareState . '.' . $instance}; + my $disk_ComponentStatus = $result2->{$oid_diskComponentStatus . '.' . $instance}; + + $self->{components}->{physicaldisk}->{total}++; + $self->{output}->output_add(long_msg => sprintf("physical disk %s status is %s, state is %s, spare state is %s, size is %d MB [chassis: %d, index: %d].", + $disk_Name, ${$componentStatus{$disk_ComponentStatus}}[0], $state{$disk_State}, + $spareState{$disk_SpareState}, $disk_LengthInMB, $chassis_Index, $disk_Index + )); + + if ($disk_ComponentStatus != 3) { + $self->{output}->output_add(severity => ${$componentStatus{$disk_ComponentStatus}}[1], + short_msg => sprintf("physical disk %s status is %s [index: %d]", + $disk_Name, ${$componentStatus{$disk_ComponentStatus}}[0], $disk_Index)); + } + + } +} + +1; diff --git a/hardware/server/dell/openmanage/mode/hardware.pm b/hardware/server/dell/openmanage/mode/hardware.pm index 7a2e44831..777b7bd46 100644 --- a/hardware/server/dell/openmanage/mode/hardware.pm +++ b/hardware/server/dell/openmanage/mode/hardware.pm @@ -47,6 +47,7 @@ use hardware::server::dell::openmanage::mode::components::temperature; use hardware::server::dell::openmanage::mode::components::cpu; use hardware::server::dell::openmanage::mode::components::cachebattery; use hardware::server::dell::openmanage::mode::components::memory; +use hardware::server::dell::openmanage::mode::components::physicaldisk; sub new { my ($class, %options) = @_; @@ -81,6 +82,7 @@ sub global { hardware::server::dell::openmanage::mode::components::cpu::check($self); hardware::server::dell::openmanage::mode::components::cachebattery::check($self); hardware::server::dell::openmanage::mode::components::memory::check($self); + hardware::server::dell::openmanage::mode::components::physicaldisk::check($self); my $total_components = 0; my $display_by_component = ''; @@ -118,6 +120,8 @@ sub component { hardware::server::dell::openmanage::mode::components::cachebattery::check($self); } elsif ($self->{option_results}->{component} eq 'memory') { hardware::server::dell::openmanage::mode::components::memory::check($self); + } elsif ($self->{option_results}->{component} eq 'physicaldisk') { + hardware::server::dell::openmanage::mode::components::physicaldisk::check($self); }else { $self->{output}->add_option_msg(short_msg => "Wrong option. Cannot find component '" . $self->{option_results}->{component} . "'."); $self->{output}->option_exit();