Description for the new unit monitor.
Target | E9000.Blade |
Parent Monitor | System.Health.AvailabilityState |
Category | AvailabilityHealth |
Enabled | True |
Alert Generate | False |
Alert Auto Resolve | False |
Monitor Type | Microsoft.Windows.TimedScript.ThreeStateMonitorType |
Remotable | True |
Accessibility | Internal |
RunAs | Default |
<UnitMonitor ID="Huawei.BladeServer.Huawei.E9000.Snmp.Monitor.BladeStatus" Accessibility="Internal" Enabled="true" Target="E9000.Blade" ParentMonitorID="Health!System.Health.AvailabilityState" Remotable="true" Priority="Normal" TypeID="Windows!Microsoft.Windows.TimedScript.ThreeStateMonitorType" ConfirmDelivery="false">
<Category>AvailabilityHealth</Category>
<OperationalStates>
<OperationalState ID="Error" MonitorTypeStateID="Error" HealthState="Error"/>
<OperationalState ID="Warning" MonitorTypeStateID="Warning" HealthState="Warning"/>
<OperationalState ID="Success" MonitorTypeStateID="Success" HealthState="Success"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>1800</IntervalSeconds>
<SyncTime/>
<ScriptName>BladeUnitMonitor.vbs</ScriptName>
<Arguments>$MPElement$ $Target/Id$ $Target/Property[Type="NetworkLibrary!System.NetworkManagement.LogicalDevice"]/Index$ $RunAs[Name="NetworkLibrary!System.NetworkManagement.Snmp.MonitoringAccount"]/CommunityString$ $Target/Host/Property[Type="NetworkLibrary!System.NetworkManagement.Node"]/SNMPAddress$ </Arguments>
<ScriptBody>
'**********************************************************************************
' Script Name - HuaweiServerMemoryUnit
' Author:
' Description:
' Determine Unit Monitor health for Server disk
'
' (c) Copyright Huawei Inc. 2013 - All rights reserved
'**********************************************************************************
Option Explicit
On Error Resume Next
Dim oArgs
Dim exePath, snmpVer, arr, host, ws, debugFlag
Dim bladeStatus,bladeNum,community,ipAddr,blade_HealthOID,blade_Health,CurrentTime,prmDeviceID
Set oArgs = WScript.Arguments
prmDeviceID = oArgs(1)
bladeNum = oArgs(2)
community = oArgs(3)
ipAddr = oArgs(4)
exePath = "C:\"&"Program Files"&"\Huawei\snmp\snmpget.exe"
snmpVer = "2c"
debugFlag = 0
Set ws = CreateObject("WScript.Shell")
host = WScript.FullName
If LCase( right(host, len(host)-InStrRev(host,"\")) ) = "wscript.exe" Then
ws.run "cscript """ & WScript.ScriptFullName & chr(34), 0
WScript.Quit
End If
MOMDebugLog("------------------pdMonitor start------------------")
blade_HealthOID = "1.3.6.1.4.1.2011.2.82.1.82.100.1.2001.1.3."&bladeNum
blade_Health = getOidResult( blade_HealthOID)
MOMDebugLog("blade_Health:" & blade_Health)
bladeStatus = blade_Health
IF len(bladeStatus)=0 or len(bladeStatus)>2 or bladeStatus =chr(10) Then
bladeStatus = -1
Elseif bladeStatus = chr(13) Then
bladeStatus = -1
End IF
bladeStatus = bladeStatus
If bladeStatus = 2 Then
bladeStatus = "Warning"
MOMDebugLog( "Raw Status: " & bladeStatus)
ElseIf bladeStatus = 3 OR bladeStatus = 4 OR bladeStatus = 5 OR bladeStatus = 6 OR bladeStatus = 7 Then
bladeStatus = "Error"
MOMDebugLog(" Raw Status: " & bladeStatus)
else
bladeStatus = "OK"
MOMDebugLog(" Raw Status: " & bladeStatus)
End If
CurrentTime = Hour(Now)& ":" & Minute(Now) &":" &Second(Now)
MOMDebugLog("Target" & prmDeviceID & "SNMPAddr :" & ipAddr & "BladeNum :" & BladeNum & "CPUNum :" & CPUNum & "Raw Status: " & CPUStatus & "Currentime" &Currentime )
MOMDebugLog("------------------pdMonitor end------------------")
Dim oAPI, oBag
Set oAPI = CreateObject("MOM.ScriptAPI")
Set oBag = oAPI.CreatePropertyBag()
Call oBag.AddValue("Status",bladeStatus)
Call oAPI.Return(oBag)
oBag = Nothing
'*****************************************************************
' Function getOidResult
' query OID value through snmp interface.
'*****************************************************************
Public Function getOidResult (ByVal Oid)
Dim cmd, result, getResult, arr
cmd = exePath & " -v " & snmpVer & " -c " & community & " -r 3 -t 20 -O vq " & ipAddr & " " & Oid
Set getResult = ws.Exec(cmd)
result = getResult.StdOut.ReadAll
Set getResult = Nothing
IF len(result )>1 Then
IF (Mid(result ,1,1)=chr(34) And Mid(result ,len(result )-1,1)=chr(34)) Then
result = Mid(result ,2,len(result)-3) & chr(32)
End IF
End IF
getOidResult = result
End Function
'*****************************************************************
' Function MOMDebugLog
' Add LogMessage Header - ScriptName and Time and Logging it.
'*****************************************************************
Public Function MOMDebugLog (ByVal strMessage)
IF debugFlag = 1 then
Const ForReading = 1, ForWriting = 2, ForAppending = 8
Set fso=CreateObject("Scripting.FileSystemObject")
if fso.folderExists("C:\scomLog") then
Dim fso, f
Set f = fso.OpenTextFile("c:\scomLog\BladeUnitMonitor.txt", ForAppending, True)
f.WriteLine strMessage
f.Close
End if
End if
End Function
</ScriptBody>
<TimeoutSeconds>300</TimeoutSeconds>
<ErrorExpression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>Property[@Name='Status']</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value Type="String">Error</Value>
</ValueExpression>
</SimpleExpression>
</ErrorExpression>
<WarningExpression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>Property[@Name='Status']</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value Type="String">Warning</Value>
</ValueExpression>
</SimpleExpression>
</WarningExpression>
<SuccessExpression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>Property[@Name='Status']</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value Type="String">OK</Value>
</ValueExpression>
</SimpleExpression>
</SuccessExpression>
</Configuration>
</UnitMonitor>