NetApp SolidFire (REST)
Description
This connector discovers and collects hardware health metrics for NetApp SolidFire storage systems and communicates directly with the NetApp SolidFire System.
Enterprise Connector
This connector requires the Enterprise edition of MetricsHub.
Target
Typical platform: NetApp SolidFire
Operating system: Storage System
This connector is not available for the local host (it is applicable to remote hosts only).
Prerequisites
Leverages: SolidFire API
Technology and protocols: HTTP
Examples
CLI
metricshub HOSTNAME -t storage -c +NetAppSolidFireREST --https --http-port 443 -u USERNAME
metricshub.yaml
resourceGroups:
<RESOURCE_GROUP>:
resources:
<HOSTNAME-ID>:
attributes:
host.name: <HOSTNAME> # Change with actual host name
host.type: storage
connectors: [ +NetAppSolidFireREST ] # Optional, to load only this connector
protocols:
http:
https: true
port: 443 # or probably something else
username: <USERNAME> # Change with actual credentials
password: <PASSWORD> # Encrypted using metricshub-encrypt
Connector Activation Criteria
The NetApp SolidFire (REST) connector will be automatically activated, and its status will be reported as OK if all the below criteria are met:
- The HTTP Request below to the managed host succeeds:
- POST
/json-rpc/9.0 - Request Header:
Content-Type:text/plain - Request Body:
{"method" : "GetClusterInfo", "id" : "Detection" } - The response body contains:
{"id":"Detection"(regex)
- POST
Metrics
| Type | Collected Metrics | Specific Attributes |
|---|---|---|
| cpu | hw.cpu.speed.limit{limit_type="max"}hw.status{hw.type="cpu", state="degraded|failed|ok"}hw.status{hw.type="cpu", state="present"} | hw.parent.idhw.parent.typeidmodelnamevendor |
| disk_controller | hw.status{hw.type="disk_controller", state="degraded|failed|ok"}hw.status{hw.type="disk_controller", state="present"} | firmware_versionhw.parent.idhw.parent.typeidmodelnameserial_number |
| enclosure | hw.enclosure.energyhw.enclosure.powerhw.status{hw.type="enclosure", state="present"} | idmodelnameserial_numbertypevendor |
| fan | hw.fan.speedhw.fan.speed.limit{limit_type="low.critical"}hw.fan.speed.limit{limit_type="low.degraded"}hw.status{hw.type="fan", state="degraded|failed|ok"}hw.status{hw.type="fan", state="present"} | hw.parent.idhw.parent.typeidname |
| logical_disk | hw.logical_disk.limithw.status{hw.type="logical_disk", state="degraded|failed|ok"} | hw.parent.idhw.parent.typeidname |
| memory | hw.memory.limithw.status{hw.type="memory", state="degraded|failed|ok"}hw.status{hw.type="memory", state="present"} | hw.parent.idhw.parent.typeidname |
| network | hw.network.bandwidth.limithw.network.uphw.status{hw.type="network", state="degraded|failed|ok"}hw.status{hw.type="network", state="present"} | hw.parent.idhw.parent.typeidlogical_addresslogical_address_typemodelnamephysical_addressphysical_address_type |
| physical_disk | hw.physical_disk.sizehw.status{hw.type="physical_disk", state="degraded|failed|ok"}hw.status{hw.type="physical_disk", state="present"} | hw.parent.idhw.parent.typeidinfomodelnameserial_numbervendor |
| power_supply | hw.status{hw.type="power_supply", state="degraded|failed|ok"}hw.status{hw.type="power_supply", state="present"} | hw.parent.idhw.parent.typeidname |
| temperature | hw.status{hw.type="temperature", state="degraded|failed|ok"}hw.status{hw.type="temperature", state="present"}hw.temperaturehw.temperature.limit{limit_type="high.critical"}hw.temperature.limit{limit_type="high.degraded"} | hw.parent.idhw.parent.typeidname |
| voltage | hw.status{hw.type="voltage", state="degraded|failed|ok"}hw.status{hw.type="voltage", state="present"}hw.voltagehw.voltage.limit{limit_type="high.critical"}hw.voltage.limit{limit_type="low.critical"} | hw.parent.idhw.parent.typeidname |