# HPE MSA 2060 Storage by HTTP ## Overview The template to monitor HPE MSA 2060 by HTTP. It works without any external scripts and uses the script item. ## Requirements Zabbix version: 7.0 and higher. ## Tested versions This template has been tested on: - HPE MSA 2060 Storage ## Configuration > Zabbix should be configured according to the instructions in the [Templates out of the box](https://www.zabbix.com/documentation/7.0/manual/config/templates_out_of_the_box) section. ## Setup 1. Create user "zabbix" with monitor role on the storage. 2. Link the template to a host. 3. Configure {$HPE.MSA.API.PASSWORD} and an interface with address through which API is accessible. 4. Change {$HPE.MSA.API.SCHEME} and {$HPE.MSA.API.PORT} macros if needed. ### Macros used |Name|Description|Default| |----|-----------|-------| |{$HPE.MSA.API.SCHEME}|
Connection scheme for API.
|`https`| |{$HPE.MSA.API.PORT}|Connection port for API.
|`443`| |{$HPE.MSA.DATA.TIMEOUT}|Response timeout for API.
|`30s`| |{$HPE.MSA.API.USERNAME}|Specify user name for API.
|`zabbix`| |{$HPE.MSA.API.PASSWORD}|Specify password for API.
|| |{$HPE.MSA.DISKS.GROUP.PUSED.MAX.WARN}|The warning threshold of the disk group space utilization in %.
|`80`| |{$HPE.MSA.DISKS.GROUP.PUSED.MAX.CRIT}|The critical threshold of the disk group space utilization in %.
|`90`| |{$HPE.MSA.POOL.PUSED.MAX.WARN}|The warning threshold of the pool space utilization in %.
|`80`| |{$HPE.MSA.POOL.PUSED.MAX.CRIT}|The critical threshold of the pool space utilization in %.
|`90`| |{$HPE.MSA.CONTROLLER.CPU.UTIL.CRIT}|The critical threshold of the CPU utilization expressed in %.
|`90`| ### Items |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |HPE MSA: Get data|The JSON with result of API requests.
|Script|hpe.msa.get.data| |Get system|The system data.
|Dependent item|hpe.msa.get.system**Preprocessing**
JSON Path: `$.system[0]`
⛔️Custom on fail: Discard value
FRU data.
|Dependent item|hpe.msa.get.fru**Preprocessing**
JSON Path: `$.['frus']`
⛔️Custom on fail: Discard value
Fans data.
|Dependent item|hpe.msa.get.fans**Preprocessing**
JSON Path: `$.['fans']`
⛔️Custom on fail: Discard value
Disks data.
|Dependent item|hpe.msa.get.disks**Preprocessing**
JSON Path: `$.['disks']`
⛔️Custom on fail: Discard value
Enclosures data.
|Dependent item|hpe.msa.get.enclosures**Preprocessing**
JSON Path: `$.['enclosures']`
⛔️Custom on fail: Discard value
Ports data.
|Dependent item|hpe.msa.get.ports**Preprocessing**
JSON Path: `$.['ports']`
⛔️Custom on fail: Discard value
Power supplies data.
|Dependent item|hpe.msa.get.power_supplies**Preprocessing**
JSON Path: `$.['power-supplies']`
⛔️Custom on fail: Discard value
Pools data.
|Dependent item|hpe.msa.get.pools**Preprocessing**
JSON Path: `$.['pools']`
⛔️Custom on fail: Discard value
Controllers data.
|Dependent item|hpe.msa.get.controllers**Preprocessing**
JSON Path: `$.['controllers']`
⛔️Custom on fail: Discard value
Controllers statistics data.
|Dependent item|hpe.msa.get.controller_statistics**Preprocessing**
JSON Path: `$.['controller-statistics']`
⛔️Custom on fail: Discard value
Disk groups data.
|Dependent item|hpe.msa.get.disks.groups**Preprocessing**
JSON Path: `$.['disk-groups']`
⛔️Custom on fail: Discard value
Disk groups statistics data.
|Dependent item|hpe.msa.disks.get.groups.statistics**Preprocessing**
JSON Path: `$.['disk-group-statistics']`
⛔️Custom on fail: Discard value
Volumes data.
|Dependent item|hpe.msa.get.volumes**Preprocessing**
JSON Path: `$.['volumes']`
⛔️Custom on fail: Discard value
Volumes statistics data.
|Dependent item|hpe.msa.get.volumes.statistics**Preprocessing**
JSON Path: `$.['volume-statistics']`
⛔️Custom on fail: Discard value
A list of method errors from API requests.
|Dependent item|hpe.msa.get.errors**Preprocessing**
JSON Path: `$.['errors']`
Discard unchanged with heartbeat: `1d`
The product model identifier.
|Dependent item|hpe.msa.system.product_id**Preprocessing**
JSON Path: `$.['product-id']`
Discard unchanged with heartbeat: `1d`
The name of the person who administers the system.
|Dependent item|hpe.msa.system.contact**Preprocessing**
JSON Path: `$.['system-contact']`
Discard unchanged with heartbeat: `1d`
A brief description of what the system is used for or how it is configured.
|Dependent item|hpe.msa.system.info**Preprocessing**
JSON Path: `$.['system-information']`
Discard unchanged with heartbeat: `1d`
The location of the system.
|Dependent item|hpe.msa.system.location**Preprocessing**
JSON Path: `$.['system-location']`
Discard unchanged with heartbeat: `1d`
The name of the storage system.
|Dependent item|hpe.msa.system.name**Preprocessing**
JSON Path: `$.['system-name']`
Discard unchanged with heartbeat: `1d`
The vendor name.
|Dependent item|hpe.msa.system.vendor_name**Preprocessing**
JSON Path: `$.['vendor-name']`
Discard unchanged with heartbeat: `1d`
System health status.
|Dependent item|hpe.msa.system.health**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Check if HTTP/HTTPS service accepts TCP connections.
|Simple check|net.tcp.service["{$HPE.MSA.API.SCHEME}","{HOST.CONN}","{$HPE.MSA.API.PORT}"]**Preprocessing**
Discard unchanged with heartbeat: `1h`
There are errors in method requests to API.
|`length(last(/HPE MSA 2060 Storage by HTTP/hpe.msa.get.errors))>0`|Average|**Depends on**:System health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.system.health)=1`|Warning|| |System health is in fault state|System health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.system.health)=2`|Average|| |System health is in unknown state|System health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.system.health)=3`|Info|| |Service is down or unavailable|HTTP/HTTPS service is down or unable to establish TCP connection.
|`max(/HPE MSA 2060 Storage by HTTP/net.tcp.service["{$HPE.MSA.API.SCHEME}","{HOST.CONN}","{$HPE.MSA.API.PORT}"],5m)=0`|High|| ### LLD rule Controllers discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Controllers discovery|Discover controllers.
|Dependent item|hpe.msa.controllers.discovery| ### Item prototypes for Controllers discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Controller [{#CONTROLLER.ID}]: Get data|The discovered controller data.
|Dependent item|hpe.msa.get.controllers["{#CONTROLLER.ID}",data]**Preprocessing**
JSON Path: `$.[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
The discovered controller statistics data.
|Dependent item|hpe.msa.get.controller_statistics["{#CONTROLLER.ID}",data]**Preprocessing**
JSON Path: `$.[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
Storage controller firmware version.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",firmware]**Preprocessing**
JSON Path: `$.['sc-fw']`
Discard unchanged with heartbeat: `1d`
Part number of the controller.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",part_number]**Preprocessing**
JSON Path: `$.['part-number']`
Discard unchanged with heartbeat: `1d`
Storage controller serial number.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",serial_number]**Preprocessing**
JSON Path: `$.['serial-number']`
Discard unchanged with heartbeat: `1d`
Controller health status.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Storage controller status.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
Discard unchanged with heartbeat: `1d`
Number of disks in the storage system.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",disks]**Preprocessing**
JSON Path: `$.['disks']`
Discard unchanged with heartbeat: `1d`
Number of pools in the storage system.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",pools]**Preprocessing**
JSON Path: `$.['number-of-storage-pools']`
Discard unchanged with heartbeat: `1d`
Number of disk groups in the storage system.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",disk_groups]**Preprocessing**
JSON Path: `$.['virtual-disks']`
Discard unchanged with heartbeat: `1d`
Controller network port IP address.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",ip_address]**Preprocessing**
JSON Path: `$.['ip-address']`
Discard unchanged with heartbeat: `1d`
Controller cache memory size.
|Dependent item|hpe.msa.controllers.cache["{#CONTROLLER.ID}",total]**Preprocessing**
JSON Path: `$.['cache-memory-size']`
Discard unchanged with heartbeat: `1d`
Custom multiplier: `1048576`
Percentage of write cache in use, from 0 to 100.
|Dependent item|hpe.msa.controllers.cache.write["{#CONTROLLER.ID}",util]**Preprocessing**
JSON Path: `$.['write-cache-used']`
For the controller that owns the volume, the number of times the block to be read is found in cache per second.
|Dependent item|hpe.msa.controllers.cache.read.hits["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['read-cache-hits']`
For the controller that owns the volume, the number of times the block to be read is not found in cache per second.
|Dependent item|hpe.msa.controllers.cache.read.misses["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['read-cache-misses']`
For the controller that owns the volume, the number of times the block written to is found in cache per second.
|Dependent item|hpe.msa.controllers.cache.write.hits["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['write-cache-hits']`
For the controller that owns the volume, the number of times the block written to is not found in cache per second.
|Dependent item|hpe.msa.controllers.cache.write.misses["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['write-cache-misses']`
Percentage of time the CPU is busy, from 0 to 100.
|Dependent item|hpe.msa.controllers.cpu["{#CONTROLLER.ID}",util]**Preprocessing**
JSON Path: `$.['cpu-load']`
Input/output operations per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.controllers.iops.total["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['iops']`
Number of read operations per second.
|Dependent item|hpe.msa.controllers.iops.read["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['number-of-reads']`
Number of write operations per second.
|Dependent item|hpe.msa.controllers.iops.write["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['number-of-writes']`
The data transfer rate, in bytes per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.controllers.data_transfer.total["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['bytes-per-second-numeric']`
The data read rate, in bytes per second.
|Dependent item|hpe.msa.controllers.data_transfer.reads["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['data-read-numeric']`
The data write rate, in bytes per second.
|Dependent item|hpe.msa.controllers.data_transfer.writes["{#CONTROLLER.ID}",rate]**Preprocessing**
JSON Path: `$.['data-written-numeric']`
Number of seconds since the controller was restarted.
|Dependent item|hpe.msa.controllers["{#CONTROLLER.ID}",uptime]**Preprocessing**
JSON Path: `$.['power-on-time']`
Controller health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers["{#CONTROLLER.ID}",health])=1`|Warning|**Depends on**:Controller health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers["{#CONTROLLER.ID}",health])=2`|Average|**Depends on**:Controller health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers["{#CONTROLLER.ID}",health])=3`|Info|**Depends on**:The controller is down.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers["{#CONTROLLER.ID}",status])=1`|High|| |Controller [{#CONTROLLER.ID}]: High CPU utilization|Controller CPU utilization is too high. The system might be slow to respond.
|`min(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers.cpu["{#CONTROLLER.ID}",util],5m)>{$HPE.MSA.CONTROLLER.CPU.UTIL.CRIT}`|Warning|| |Controller [{#CONTROLLER.ID}]: Controller has been restarted|The controller uptime is less than 10 minutes.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.controllers["{#CONTROLLER.ID}",uptime])<10m`|Warning|| ### LLD rule Disk groups discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Disk groups discovery|Discover disk groups.
|Dependent item|hpe.msa.disks.groups.discovery| ### Item prototypes for Disk groups discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Disk group [{#NAME}]: Get data|The discovered disk group data.
|Dependent item|hpe.msa.get.disks.groups["{#NAME}",data]**Preprocessing**
JSON Path: `$.[?(@['name'] == "{#NAME}")].first()`
The discovered disk group statistics data.
|Dependent item|hpe.msa.get.disks.groups.statistics["{#NAME}",data]**Preprocessing**
JSON Path: `$.[?(@['name'] == "{#NAME}")].first()`
Number of disks in the disk group.
|Dependent item|hpe.msa.disks.groups["{#NAME}",disk_count]**Preprocessing**
JSON Path: `$.['diskcount']`
⛔️Custom on fail: Discard value
Discard unchanged with heartbeat: `1h`
The percentage of pool capacity that the disk group occupies.
|Dependent item|hpe.msa.disks.groups.space["{#NAME}",pool_util]**Preprocessing**
JSON Path: `$.['pool-percentage']`
Discard unchanged with heartbeat: `1h`
Disk group health.
|Dependent item|hpe.msa.disks.groups["{#NAME}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
The size of a block, in bytes.
|Dependent item|hpe.msa.disks.groups.blocks["{#NAME}",size]**Preprocessing**
JSON Path: `$.['blocksize']`
Discard unchanged with heartbeat: `1h`
Free space in blocks.
|Dependent item|hpe.msa.disks.groups.blocks["{#NAME}",free]**Preprocessing**
JSON Path: `$.['freespace-numeric']`
Discard unchanged with heartbeat: `1h`
Total space in blocks.
|Dependent item|hpe.msa.disks.groups.blocks["{#NAME}",total]**Preprocessing**
JSON Path: `$.['blocks']`
Discard unchanged with heartbeat: `1h`
The free space in the disk group.
|Calculated|hpe.msa.disks.groups.space["{#NAME}",free]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The capacity of the disk group.
|Calculated|hpe.msa.disks.groups.space["{#NAME}",total]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The space utilization percentage in the disk group.
|Calculated|hpe.msa.disks.groups.space["{#NAME}",util]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The RAID level of the disk group.
|Dependent item|hpe.msa.disks.groups.raid["{#NAME}",type]**Preprocessing**
JSON Path: `$.['raidtype-numeric']`
Discard unchanged with heartbeat: `1d`
The status of the disk group:
- CRIT: Critical. The disk group is online but isn't fault tolerant because some of it's disks are down.
- DMGD: Damaged. The disk group is online and fault tolerant, but some of it's disks are damaged.
- FTDN: Fault tolerant with a down disk.The disk group is online and fault tolerant, but some of it's disks are down.
- FTOL: Fault tolerant.
- MSNG: Missing. The disk group is online and fault tolerant, but some of it's disks are missing.
- OFFL: Offline. Either the disk group is using offline initialization, or it's disks are down and data may be lost.
- QTCR: Quarantined critical. The disk group is critical with at least one inaccessible disk. For example, two disks are inaccessible in a RAID 6 disk group or one disk is inaccessible for other fault-tolerant RAID levels. If the inaccessible disks come online or if after 60 seconds from being quarantined the disk group is QTCRor QTDN, the disk group is automatically dequarantined.
- QTDN: Quarantined with a down disk. The RAID6 disk group has one inaccessible disk. The disk group is fault tolerant but degraded. If the inaccessible disks come online or if after 60 seconds from being quarantined the disk group is QTCRor QTDN, the disk group is automatically dequarantined.
- QTOF: Quarantined offline. The disk group is offline with multiple inaccessible disks causing user data to be incomplete, or is an NRAID or RAID 0 disk group.
- QTUN: Quarantined unsupported. The disk group contains data in a format that is not supported by this system. For example, this system does not support linear disk groups.
- STOP: The disk group is stopped.
- UNKN: Unknown.
- UP: Up. The disk group is online and does not have fault-tolerant attributes.
|Dependent item|hpe.msa.disks.groups["{#NAME}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
Discard unchanged with heartbeat: `1h`
Input/output operations per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.disks.groups.iops.total["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['iops']`
Average response time for read and write operations, calculated over the interval since these statistics were last requested or reset.
|Dependent item|hpe.msa.disks.groups.avg_rsp_time["{#NAME}",total]**Preprocessing**
JSON Path: `$.['avg-rsp-time']`
Custom multiplier: `0.000001`
Average response time for all read operations, calculated over the interval since these statistics were last requested or reset.
|Dependent item|hpe.msa.disks.groups.avg_rsp_time["{#NAME}",read]**Preprocessing**
JSON Path: `$.['avg-read-rsp-time']`
Custom multiplier: `0.000001`
Average response time for all write operations, calculated over the interval since these statistics were last requested or reset.
|Dependent item|hpe.msa.disks.groups.avg_rsp_time["{#NAME}",write]**Preprocessing**
JSON Path: `$.['avg-write-rsp-time']`
Custom multiplier: `0.000001`
Number of read operations per second.
|Dependent item|hpe.msa.disks.groups.iops.read["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['number-of-reads']`
Number of write operations per second.
|Dependent item|hpe.msa.disks.groups.iops.write["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['number-of-writes']`
The data transfer rate, in bytes per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.disks.groups.data_transfer.total["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['bytes-per-second-numeric']`
The data read rate, in bytes per second.
|Dependent item|hpe.msa.disks.groups.data_transfer.reads["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['data-read-numeric']`
The data write rate, in bytes per second.
|Dependent item|hpe.msa.disks.groups.data_transfer.writes["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['data-written-numeric']`
Disk group health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",health])=1`|Warning|| |Disk group [{#NAME}]: Disk group health is in fault state|Disk group health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",health])=2`|Average|| |Disk group [{#NAME}]: Disk group health is in unknown state|Disk group health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",health])=3`|Info|| |Disk group [{#NAME}]: Disk group space is low|Disk group is running low on free space (less than {$HPE.MSA.DISKS.GROUP.PUSED.MAX.WARN:"{#NAME}"}% available).
|`min(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups.space["{#NAME}",util],5m)>{$HPE.MSA.DISKS.GROUP.PUSED.MAX.WARN:"{#NAME}"}`|Warning|**Depends on**:Disk group is running low on free space (less than {$HPE.MSA.DISKS.GROUP.PUSED.MAX.CRIT:"{#NAME}"}% available).
|`min(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups.space["{#NAME}",util],5m)>{$HPE.MSA.DISKS.GROUP.PUSED.MAX.CRIT:"{#NAME}"}`|Average|| |Disk group [{#NAME}]: Disk group is fault tolerant with a down disk|The disk group is online and fault tolerant, but some of it's disks are down.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=1`|Average|| |Disk group [{#NAME}]: Disk group has damaged disks|The disk group is online and fault tolerant, but some of it's disks are damaged.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=9`|Average|| |Disk group [{#NAME}]: Disk group has missing disks|The disk group is online and fault tolerant, but some of it's disks are missing.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=8`|Average|| |Disk group [{#NAME}]: Disk group is offline|Either the disk group is using offline initialization, or it's disks are down and data may be lost.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=3`|Average|| |Disk group [{#NAME}]: Disk group is quarantined critical|The disk group is critical with at least one inaccessible disk. For example, two disks are inaccessible in a RAID 6 disk group or one disk is inaccessible for other fault-tolerant RAID levels. If the inaccessible disks come online or if after 60 seconds from being quarantined the disk group is QTCRor QTDN, the disk group is automatically dequarantined.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=4`|Average|| |Disk group [{#NAME}]: Disk group is quarantined offline|The disk group is offline with multiple inaccessible disks causing user data to be incomplete, or is an NRAID or RAID 0 disk group.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=5`|Average|| |Disk group [{#NAME}]: Disk group is quarantined unsupported|The disk group contains data in a format that is not supported by this system. For example, this system does not support linear disk groups.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=5`|Average|| |Disk group [{#NAME}]: Disk group is quarantined with an inaccessible disk|The RAID6 disk group has one inaccessible disk. The disk group is fault tolerant but degraded. If the inaccessible disks come online or if after 60 seconds from being quarantined the disk group is QTCRor QTDN, the disk group is automatically dequarantined.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=6`|Average|| |Disk group [{#NAME}]: Disk group is stopped|The disk group is stopped.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=7`|Average|| |Disk group [{#NAME}]: Disk group status is critical|The disk group is online but isn't fault tolerant because some of its disks are down.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks.groups["{#NAME}",status])=2`|Average|| ### LLD rule Pools discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Pools discovery|Discover pools.
|Dependent item|hpe.msa.pools.discovery| ### Item prototypes for Pools discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Pool [{#NAME}]: Get data|The discovered pool data.
|Dependent item|hpe.msa.get.pools["{#NAME}",data]**Preprocessing**
JSON Path: `$[?(@['name'] == "{#NAME}")].first()`
Pool health.
|Dependent item|hpe.msa.pools["{#NAME}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
The size of a block, in bytes.
|Dependent item|hpe.msa.pools.blocks["{#NAME}",size]**Preprocessing**
JSON Path: `$.['blocksize']`
Discard unchanged with heartbeat: `1h`
Available space in blocks.
|Dependent item|hpe.msa.pools.blocks["{#NAME}",available]**Preprocessing**
JSON Path: `$.['total-avail-numeric']`
Discard unchanged with heartbeat: `1h`
Total space in blocks.
|Dependent item|hpe.msa.pools.blocks["{#NAME}",total]**Preprocessing**
JSON Path: `$.['total-size-numeric']`
Discard unchanged with heartbeat: `1h`
The free space in the pool.
|Calculated|hpe.msa.pools.space["{#NAME}",free]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The capacity of the pool.
|Calculated|hpe.msa.pools.space["{#NAME}",total]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The space utilization percentage in the pool.
|Calculated|hpe.msa.pools.space["{#NAME}",util]**Preprocessing**
Discard unchanged with heartbeat: `1h`
Pool health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.pools["{#NAME}",health])=1`|Warning|| |Pool [{#NAME}]: Pool health is in fault state|Pool health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.pools["{#NAME}",health])=2`|Average|| |Pool [{#NAME}]: Pool health is in unknown state|Pool [{#NAME}] health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.pools["{#NAME}",health])=3`|Info|| |Pool [{#NAME}]: Pool space is low|Pool is running low on free space (less than {$HPE.MSA.POOL.PUSED.MAX.WARN:"{#NAME}"}% available).
|`min(/HPE MSA 2060 Storage by HTTP/hpe.msa.pools.space["{#NAME}",util],5m)>{$HPE.MSA.POOL.PUSED.MAX.WARN:"{#NAME}"}`|Warning|**Depends on**:Pool is running low on free space (less than {$HPE.MSA.POOL.PUSED.MAX.CRIT:"{#NAME}"}% available).
|`min(/HPE MSA 2060 Storage by HTTP/hpe.msa.pools.space["{#NAME}",util],5m)>{$HPE.MSA.POOL.PUSED.MAX.CRIT:"{#NAME}"}`|Average|| ### LLD rule Volumes discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Volumes discovery|Discover volumes.
|Dependent item|hpe.msa.volumes.discovery| ### Item prototypes for Volumes discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Volume [{#NAME}]: Get data|The discovered volume data.
|Dependent item|hpe.msa.get.volumes["{#NAME}",data]**Preprocessing**
JSON Path: `$.[?(@['volume-name'] == "{#NAME}")].first()`
The discovered volume statistics data.
|Dependent item|hpe.msa.get.volumes.statistics["{#NAME}",data]**Preprocessing**
JSON Path: `$.[?(@['volume-name'] == "{#NAME}")].first()`
The size of a block, in bytes.
|Dependent item|hpe.msa.volumes.blocks["{#NAME}",size]**Preprocessing**
JSON Path: `$.['blocksize']`
Discard unchanged with heartbeat: `1h`
The amount of blocks currently allocated to the volume.
|Dependent item|hpe.msa.volumes.blocks["{#NAME}",allocated]**Preprocessing**
JSON Path: `$.['allocated-size-numeric']`
Discard unchanged with heartbeat: `1h`
Total space in blocks.
|Dependent item|hpe.msa.volumes.blocks["{#NAME}",total]**Preprocessing**
JSON Path: `$.['blocks']`
Discard unchanged with heartbeat: `1h`
The amount of space currently allocated to the volume.
|Calculated|hpe.msa.volumes.space["{#NAME}",allocated]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The capacity of the volume.
|Calculated|hpe.msa.volumes.space["{#NAME}",total]**Preprocessing**
Discard unchanged with heartbeat: `1h`
Total input/output operations per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.volumes.iops.total["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['iops']`
Number of read operations per second.
|Dependent item|hpe.msa.volumes.iops.read["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['number-of-reads']`
Number of write operations per second.
|Dependent item|hpe.msa.volumes.iops.write["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['number-of-writes']`
The data transfer rate, in bytes per second, calculated over the interval since these statistics were last requested or reset. This value will be zero if it has not been requested or reset since a controller restart.
|Dependent item|hpe.msa.volumes.data_transfer.total["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['bytes-per-second-numeric']`
The data read rate, in bytes per second.
|Dependent item|hpe.msa.volumes.data_transfer.reads["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['data-read-numeric']`
The data write rate, in bytes per second.
|Dependent item|hpe.msa.volumes.data_transfer.writes["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['data-written-numeric']`
For the controller that owns the volume, the number of times the block to be read is found in cache per second.
|Dependent item|hpe.msa.volumes.cache.read.hits["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['read-cache-hits']`
For the controller that owns the volume, the number of times the block to be read is not found in cache per second.
|Dependent item|hpe.msa.volumes.cache.read.misses["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['read-cache-misses']`
For the controller that owns the volume, the number of times the block written to is found in cache per second.
|Dependent item|hpe.msa.volumes.cache.write.hits["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['write-cache-hits']`
For the controller that owns the volume, the number of times the block written to is not found in cache per second.
|Dependent item|hpe.msa.volumes.cache.write.misses["{#NAME}",rate]**Preprocessing**
JSON Path: `$.['write-cache-misses']`
Discover enclosures.
|Dependent item|hpe.msa.enclosures.discovery| ### Item prototypes for Enclosures discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Enclosure [{#DURABLE.ID}]: Get data|The discovered enclosure data.
|Dependent item|hpe.msa.get.enclosures["{#DURABLE.ID}",data]**Preprocessing**
JSON Path: `$[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
Enclosure health.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Enclosure status.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
⛔️Custom on fail: Set value to: `6`
Discard unchanged with heartbeat: `1d`
Midplane serial number.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",midplane_serial_number]**Preprocessing**
JSON Path: `$.['midplane-serial-number']`
Discard unchanged with heartbeat: `1d`
Enclosure part number.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",part_number]**Preprocessing**
JSON Path: `$.['part-number']`
Discard unchanged with heartbeat: `1d`
Enclosure model.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",model]**Preprocessing**
JSON Path: `$.['model']`
Discard unchanged with heartbeat: `1d`
Enclosure power in watts.
|Dependent item|hpe.msa.enclosures["{#DURABLE.ID}",power]**Preprocessing**
JSON Path: `$.['enclosure-power']`
Enclosure health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",health])=1`|Warning|| |Enclosure [{#DURABLE.ID}]: Enclosure health is in fault state|Enclosure health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",health])=2`|Average|| |Enclosure [{#DURABLE.ID}]: Enclosure health is in unknown state|Enclosure health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",health])=3`|Info|| |Enclosure [{#DURABLE.ID}]: Enclosure has critical status|Enclosure has critical status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",status])=2`|High|| |Enclosure [{#DURABLE.ID}]: Enclosure has warning status|Enclosure has warning status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",status])=3`|Warning|| |Enclosure [{#DURABLE.ID}]: Enclosure is unavailable|Enclosure is unavailable.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",status])=7`|High|| |Enclosure [{#DURABLE.ID}]: Enclosure is unrecoverable|Enclosure is unrecoverable.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",status])=4`|High|| |Enclosure [{#DURABLE.ID}]: Enclosure has unknown status|Enclosure has unknown status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.enclosures["{#DURABLE.ID}",status])=6`|Info|| ### LLD rule Power supplies discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Power supplies discovery|Discover power supplies.
|Dependent item|hpe.msa.power_supplies.discovery| ### Item prototypes for Power supplies discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Power supply [{#DURABLE.ID}]: Get data|The discovered power supply data.
|Dependent item|hpe.msa.get.power_supplies["{#DURABLE.ID}",data]**Preprocessing**
JSON Path: `$[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
Power supply health status.
|Dependent item|hpe.msa.power_supplies["{#DURABLE.ID}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Power supply status.
|Dependent item|hpe.msa.power_supplies["{#DURABLE.ID}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Power supply part number.
|Dependent item|hpe.msa.power_supplies["{#DURABLE.ID}",part_number]**Preprocessing**
JSON Path: `$.['part-number']`
Discard unchanged with heartbeat: `1d`
Power supply serial number.
|Dependent item|hpe.msa.power_supplies["{#DURABLE.ID}",serial_number]**Preprocessing**
JSON Path: `$.['serial-number']`
Discard unchanged with heartbeat: `1d`
Power supply health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",health])=1`|Warning|| |Power supply [{#DURABLE.ID}]: Power supply health is in fault state|Power supply health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",health])=2`|Average|| |Power supply [{#DURABLE.ID}]: Power supply health is in unknown state|Power supply health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",health])=3`|Info|| |Power supply [{#DURABLE.ID}]: Power supply has error status|Power supply has error status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",status])=2`|Average|| |Power supply [{#DURABLE.ID}]: Power supply has warning status|Power supply has warning status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",status])=1`|Warning|| |Power supply [{#DURABLE.ID}]: Power supply has unknown status|Power supply has unknown status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.power_supplies["{#DURABLE.ID}",status])=4`|Info|| ### LLD rule Ports discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Ports discovery|Discover ports.
|Dependent item|hpe.msa.ports.discovery| ### Item prototypes for Ports discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Port [{#NAME}]: Get data|The discovered port data.
|Dependent item|hpe.msa.get.ports["{#NAME}",,data]**Preprocessing**
JSON Path: `$[?(@['port'] == "{#NAME}")].first()`
Port health status.
|Dependent item|hpe.msa.ports["{#NAME}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Port status.
|Dependent item|hpe.msa.ports["{#NAME}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Port type.
|Dependent item|hpe.msa.ports["{#NAME}",type]**Preprocessing**
JSON Path: `$.['port-type-numeric']`
Discard unchanged with heartbeat: `1d`
Port health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",health])=1`|Warning|| |Port [{#NAME}]: Port health is in fault state|Port health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",health])=2`|Average|| |Port [{#NAME}]: Port health is in unknown state|Port health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",health])=3`|Info|| |Port [{#NAME}]: Port has error status|Port has error status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",status])=2`|Average|| |Port [{#NAME}]: Port has warning status|Port has warning status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",status])=1`|Warning|| |Port [{#NAME}]: Port has unknown status|Port has unknown status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.ports["{#NAME}",status])=4`|Info|| ### LLD rule Fans discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Fans discovery|Discover fans.
|Dependent item|hpe.msa.fans.discovery| ### Item prototypes for Fans discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Fan [{#DURABLE.ID}]: Get data|The discovered fan data.
|Dependent item|hpe.msa.get.fans["{#DURABLE.ID}",data]**Preprocessing**
JSON Path: `$[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
Fan health status.
|Dependent item|hpe.msa.fans["{#DURABLE.ID}",health]**Preprocessing**
JSON Path: `$.['health-numeric']`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Fan status.
|Dependent item|hpe.msa.fans["{#DURABLE.ID}",status]**Preprocessing**
JSON Path: `$.['status-numeric']`
Discard unchanged with heartbeat: `1h`
Fan speed (revolutions per minute).
|Dependent item|hpe.msa.fans["{#DURABLE.ID}",speed]**Preprocessing**
JSON Path: `$.['speed']`
Fan health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",health])=1`|Warning|| |Fan [{#DURABLE.ID}]: Fan health is in fault state|Fan health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",health])=2`|Average|| |Fan [{#DURABLE.ID}]: Fan health is in unknown state|Fan health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",health])=3`|Info|| |Fan [{#DURABLE.ID}]: Fan has error status|Fan has error status.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",status])=1`|Average|| |Fan [{#DURABLE.ID}]: Fan is missing|Fan is missing.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",status])=3`|Info|| |Fan [{#DURABLE.ID}]: Fan is off|Fan is off.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.fans["{#DURABLE.ID}",status])=2`|Warning|| ### LLD rule Disks discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Disks discovery|Discover disks.
|Dependent item|hpe.msa.disks.discovery| ### Item prototypes for Disks discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Disk [{#DURABLE.ID}]: Get data|The discovered disk data.
|Dependent item|hpe.msa.get.disks["{#DURABLE.ID}",data]**Preprocessing**
JSON Path: `$[?(@['durable-id'] == "{#DURABLE.ID}")].first()`
Disk health status.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",health]**Preprocessing**
JSON Path: `$.['health-numeric'].first()`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Disk temperature status.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",temperature_status]**Preprocessing**
JSON Path: `$.['temperature-status-numeric']`
⛔️Custom on fail: Discard value
In range: `1 -> 3`
⛔️Custom on fail: Set value to: `4`
Discard unchanged with heartbeat: `1h`
Temperature of the disk.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",temperature]**Preprocessing**
JSON Path: `$.['temperature-numeric']`
⛔️Custom on fail: Discard value
Discard unchanged with heartbeat: `1h`
Disk type:
SAS: Enterprise SAS spinning disk.
SAS MDL: Midline SAS spinning disk.
SSD SAS: SAS solit-state disk.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",type]**Preprocessing**
JSON Path: `$.['description-numeric']`
Discard unchanged with heartbeat: `1d`
If the disk is in a disk group, the disk group name.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",group]**Preprocessing**
JSON Path: `$.['disk-group']`
⛔️Custom on fail: Discard value
Discard unchanged with heartbeat: `1d`
If the disk is in a pool, the pool name.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",pool]**Preprocessing**
JSON Path: `$.['storage-pool-name']`
⛔️Custom on fail: Discard value
Discard unchanged with heartbeat: `1d`
Disk vendor.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",vendor]**Preprocessing**
JSON Path: `$.['vendor']`
Discard unchanged with heartbeat: `1d`
Disk model.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",model]**Preprocessing**
JSON Path: `$.['model']`
Discard unchanged with heartbeat: `1d`
Disk serial number.
|Dependent item|hpe.msa.disks["{#DURABLE.ID}",serial_number]**Preprocessing**
JSON Path: `$.['serial-number']`
Discard unchanged with heartbeat: `1d`
The size of a block, in bytes.
|Dependent item|hpe.msa.disks.blocks["{#DURABLE.ID}",size]**Preprocessing**
JSON Path: `$.['blocksize']`
Discard unchanged with heartbeat: `1h`
Total space in blocks.
|Dependent item|hpe.msa.disks.blocks["{#DURABLE.ID}",total]**Preprocessing**
JSON Path: `$.['blocks']`
Discard unchanged with heartbeat: `1h`
Total size of the disk.
|Calculated|hpe.msa.disks.space["{#DURABLE.ID}",total]**Preprocessing**
Discard unchanged with heartbeat: `1d`
The percentage of disk life remaining.
|Dependent item|hpe.msa.disks.ssd["{#DURABLE.ID}",life_left]**Preprocessing**
JSON Path: `$.['ssd-life-left-numeric']`
Discard unchanged with heartbeat: `1h`
Disk health is in degraded state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",health])=1`|Warning|| |Disk [{#DURABLE.ID}]: Disk health is in fault state|Disk health is in fault state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",health])=2`|Average|| |Disk [{#DURABLE.ID}]: Disk health is in unknown state|Disk health is in unknown state.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",health])=3`|Info|| |Disk [{#DURABLE.ID}]: Disk temperature is high|Disk temperature is high.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",temperature_status])=3`|Warning|| |Disk [{#DURABLE.ID}]: Disk temperature is critically high|Disk temperature is critically high.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",temperature_status])=2`|Average|| |Disk [{#DURABLE.ID}]: Disk temperature is unknown|Disk temperature is unknown.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.disks["{#DURABLE.ID}",temperature_status])=4`|Info|| ### LLD rule FRU discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |FRU discovery|Discover FRU.
|Dependent item|hpe.msa.frus.discovery| ### Item prototypes for FRU discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |FRU [{#ENCLOSURE.ID}: {#LOCATION}]: Get data|The discovered FRU data.
|Dependent item|hpe.msa.get.frus["{#ENCLOSURE.ID}:{#LOCATION}",data]**Preprocessing**
JSON Path: `$[?(@['name'] == "{#TYPE}")].first()`
{#DESCRIPTION}. FRU status:
Absent: The FRU is not present.
Fault: The FRU's health is Degraded or Fault.
Invalid data: The FRU ID data is invalid. The FRU's EEPROM is improperly programmed.
OK: The FRU is operating normally.
Power off: The FRU is powered off.
|Dependent item|hpe.msa.frus["{#ENCLOSURE.ID}:{#LOCATION}",status]**Preprocessing**
JSON Path: `$.['fru-status-numeric']`
Discard unchanged with heartbeat: `1h`
{#DESCRIPTION}. Part number of the FRU.
|Dependent item|hpe.msa.frus["{#ENCLOSURE.ID}:{#LOCATION}",part_number]**Preprocessing**
JSON Path: `$.['part-number']`
Discard unchanged with heartbeat: `1d`
{#DESCRIPTION}. FRU serial number.
|Dependent item|hpe.msa.frus["{#ENCLOSURE.ID}:{#LOCATION}",serial_number]**Preprocessing**
JSON Path: `$.['serial-number']`
Discard unchanged with heartbeat: `1d`
FRU status is Degraded or Fault.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.frus["{#ENCLOSURE.ID}:{#LOCATION}",status])=1`|Average|| |FRU [{#ENCLOSURE.ID}: {#LOCATION}]: FRU ID data is invalid|The FRU ID data is invalid. The FRU's EEPROM is improperly programmed.
|`last(/HPE MSA 2060 Storage by HTTP/hpe.msa.frus["{#ENCLOSURE.ID}:{#LOCATION}",status])=0`|Warning|| ## Feedback Please report any issues with the template at [`https://support.zabbix.com`](https://support.zabbix.com) You can also provide feedback, discuss the template, or ask for help at [`ZABBIX forums`](https://www.zabbix.com/forum/zabbix-suggestions-and-feedback)