20
CIMDIFF: Advanced Difference Tracking Tool for CIM Compliant Devices Ramani Routray Shripad Nadgowda IBM Research – Almaden IBM System and Technology Lab, Pune © 2009 IBM Corporation

CIMDIFF: Advanced Difference Tracking Tool for CIM

  • Upload
    others

  • View
    3

  • Download
    0

Embed Size (px)

Citation preview

CIMDIFF: Advanced Difference Tracking Tool for CIM Compliant Devices

Ramani Routray Shripad NadgowdaIBM Research – Almaden IBM System and Technology Lab, Pune

© 2009 IBM Corporation

USENIX LISA 2009

Outline

� Background

� Model and Problem Definition

� System Overview

� Implementation

© 2009 IBM Corporation2

� Results

� Conclusion and Future Work

Source: If applicable, describe source origin

USENIX LISA 2009

Background (I)

CIM Agent

Providers

CIMOMIndication

Security

Repository

CIM ClientCIM-XML/HTTP

MOF

Web Based Enterprise Management (WBEM)

CIM_ManagedElement

© 2009 IBM Corporation3

Source: If applicable, describe source origin

CIM_ManagedElement

CIM_ManagedSystemElement

CIM_LogicalElement

CIM_EnabledLogicalElement

CIM_System

CIM_ComputerSystem CIM_FCPort

CIM_NetworkPort

CIM_LogicalPort

CIM_LogicalDevice

CIM_EnabledLogicalElement

USENIX LISA 2009

Background (II)

<?xml version="1.0" ?>

<CIM CIMVERSION="2.0" DTDVERSION="2.0">

<MESSAGE ID="0" PROTOCOLVERSION="1.0">

...

<INSTANCENAME CLASSNAME="IBMTSDS_StorageSystem">

<KEYBINDING NAME="Name">

<KEYVALUE VALUETYPE="string">

IBM.1750-6887010

</KEYVALUE>

</KEYBINDING>

<KEYBINDING NAME="CreationClassName">

<KEYVALUE VALUETYPE="string">

IBMTSDS_StorageSystem

CIMObjectpath

(Key CIM Properties)

© 2009 IBM Corporation4

Source: If applicable, describe source origin

IBMTSDS_StorageSystem

</KEYVALUE>

</KEYBINDING>

</INSTANCENAME>

<INSTANCE CLASSNAME="IBMTSDS_StorageSystem">

<PROPERTY NAME="CodeLevel" TYPE="string">

<VALUE TYPE="string">5.2.2.399</VALUE>

</PROPERTY>

<PROPERTY NAME="NVSMemory" TYPE="uint32">

<VALUE TYPE="uint32">256</VALUE>

</PROPERTY>

<PROPERTY NAME="CacheMemory" TYPE="uint32">

<VALUE TYPE="uint32">2629</VALUE>

</PROPERTY>

...

</INSTANCE>

CIM

Instance

(Non-Key CIM Properties)

USENIX LISA 2009

Motivation and Problem Definition

• Discovery operation by System Management tool• Administrators Query difference between systems

• XML Document difference tracking• NP Hard• Meaningful Difference Tracking

© 2009 IBM Corporation5

Source: If applicable, describe source origin

• Meaningful Difference Tracking

Cr = { N+ }

N = { Ci | Cop | Cp }

Ci = { Cop, Cp }

Cop = { Cp+ }

USENIX LISA 2009

Model and Problem Definition (II)

Temporal

Temporal-Syntactic Temporal-Semantic

Snapshot of Same CIM Agent(s)CIMInstance addition/deletion/..(e.g. CIM_StorageVolume)

Snapshot of Same CIM Agent(s)Logical Actions : Volume Assignment(e.g. CIM Instance creation/modificationVolume, Privilege, ProtocolControllerForUnitCause of Extrinsic method invocation)

© 2009 IBM Corporation6

Source: If applicable, describe source origin

Syntactic

Spatial

Semantic

Spatial-Syntactic Spatial-Semantic

Snapshot of Different CIM Agent(s)Diff in CIM Properties(e.g. CIM_StorageVolumeinstances)

Snapshot of Different CIM Agent(s)Diff in Logical Properties(e.g. TotalSpace, AvaliableSpace etc..)

USENIX LISA 2009

System Overview

CIM Repository<t0, CIMAgenta>

CIM Repository<t1, CIMAgenta>

CIM Repository<tm, CIMAgentx>

CIM Repository<tn, CIMAgenty>

INPUT

SANSimulator

© 2009 IBM Corporation7

Source: If applicable, describe source origin

OUTPUT

Difference Tracker

HashMaker

KnowledgeBase

HierarchyResolver

CIMDIFF

USENIX LISA 2009

Hash Maker

© 2009 IBM Corporation8

Source: If applicable, describe source origin

USENIX LISA 2009

KnowledgeBase (I)

© 2009 IBM Corporation9

Source: If applicable, describe source origin

USENIX LISA 2009

KnowledgeBase - Recipe

© 2009 IBM Corporation10

Source: If applicable, describe source origin

USENIX LISA 2009

KnowledgeBase – StorageVolume Creation

IBMTSDS_Volume

IBMTSDS_ExtentPool

IBMTSDS_AllocatedFromExtentPool

IBMTSDS_RankExtentIBMTSDS_VolumeDistribution

IBMTSDS_VolumeBasedOnRankExtent

C

C

C

U

E

© 2009 IBM Corporation11

Source: If applicable, describe source origin

IBMTSDS_VolumeBasedOnRankExtent

IBMTSDS_StorageSystem

IBMTSDS_StorageSystemToVolumeDistributionIBMTSDS_StorageSystemToVolume

IBMTSDS_VolStatsMemberOfCollection IBMTSDS_VolumeStatisticalData

IBMTSDS_VolumeStatistics IBMTSDS_VolumeSettingData

C CC

E

C C

C C

C

E

U

Exists

Create

Update

USENIX LISA 2009

KnowledgeBase – StorageVolume Assignment

IBMTSDS_StorageSystem

IBMTSDS_HostedVolumeGroup

IBMTSDS_VolumeGroup

IBMTSDS_MappedVolumeGroup

IBMTSDS_StorageSystemToSPC

IBMTSDS_PriviledgeManagementService

IBMTSDS_ConcreteDependecyPriviledge

IBMTSDS_Priviledge

IBMTSDS_MemberOfVolumeGroup

IBMTSDS_VolumeIBMTSDS_ProtocolControllerForUnitC E

E

C

C

C

C

C

CE

C

© 2009 IBM Corporation12

Source: If applicable, describe source origin

IBMTSDS_SCSIProtocolController

IBMTSDS_StorageHardwareID

IBMTSDS_SHWIDToSPC

IBMTSDS_ConcreteDependecncyStorageHardwareID

IBMTSDS_StorageHardwareIDManagementService

IBMTSDS_SCSIProtocolControllerEndPointIBMTSDS_SAPAvailabeForElement

IBMTSDS_StorageClientSetting

IBMTSDS_InitiatorElementSettingData

IBMTSDS_ControllerConfigurationService

IBMTSDS_ConcreteDependencyController

IBMTSDS_AuthorizesTarget

IBMTSDS_FCportIBMTSDS_ProtocolControllerForPort

IBMTSDS_AuthorizedSubject

E

E

E

E

E

C

C

C

C

C

C

CC

C

C

USENIX LISA 2009

Difference Tracker

calculateMinCostEditScripts(Cr1,Cr2)

{

/* Hashing */

Map Cr1 to T1, Map Cr2 to T2

Hash T1, Hash T2

/* Traverse CIM Agent Hierarchy */

/* Traverse Managed Device Hierarchy */

Traverse CIM Agent hierarchy &

Traverse Managed Device hierarchy

© 2009 IBM Corporation13

Source: If applicable, describe source origin

Traverse Managed Device hierarchy

{

/* Check tree isomorphism based on Hash */

/* Compute Insert, Delete, Update */

for all Node N in T1 and T2

for all CIMClass(es)

for all CIMInstance(s)

Compare CIMObjectpath

Compare CIMProperties

}

}

USENIX LISA 2009

Implementation

© 2009 IBM Corporation14

Source: If applicable, describe source origin

USENIX LISA 2009

Results

© 2009 IBM Corporation15

Source: If applicable, describe source origin

USENIX LISA 2009

Results

© 2009 IBM Corporation16

Source: If applicable, describe source origin

USENIX LISA 2009

Results

© 2009 IBM Corporation17

Source: If applicable, describe source origin

USENIX LISA 2009

Results

© 2009 IBM Corporation18

Source: If applicable, describe source origin

USENIX LISA 2009

Conclusion and Future Work

• Diff Utility• XML, GNU, CVS,…

• Multi-Hierarchical XML Document• Standards Based• KnowledgeBase Driven• Meaningful Diff Tracking

• Powerful tool for system administrators

© 2009 IBM Corporation19

Source: If applicable, describe source origin

• Powerful tool for system administrators& system management tool developers and testers

• Tool can be used in SNIA CTP Environment• Fast Changing Virtual Environment

• Using Machine learning for automatic pattern detection• Visual tool for administrator to specify pattern

USENIX LISA 2009

Thank You!

© 2009 IBM Corporation20

Thank You!

Source: If applicable, describe source origin