Table of Contents | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
Swarm calculates storage use by addressable object in order objects to support conventional (storage filer) reporting of file counts and their space usage. This approach tracks cluster-wide capacity by counting logical objects (the unique content of uploaded and versioned files) rather than actual streams (the raw space that is consumed by all Swarm components, including replicas, EC segments, context objects, and manifests). The versions add to the object totals; if a cluster held one 20 MB image with 3 replicas and 4 prior versions: 5 logical objects and ~100 MB logical space is are consumed.
Swarm continuously sends its the nodes updates about the cluster's logical usage (the current number of objects and the space they consume), which the nodes update with their own the local space-affecting activity. Swarm then aggregates Swarm aggregates these updates (for accuracy) and publishes them via using SNMP and REST as logicalObjects
and and logicalSpace
. A third statistic, logicalUnprocessed
, exists to provide insight into the accuracy of the other statistics' accuracy (the closer to zero it is, the more accurate they are). Swarm Swarm propagates this data quickly, so there is little lag behind the cluster activity that affects affecting usage: writes, deletes, and updates. After a disk failure, however, you will see a A drop in the aggregated estimates is reflected after a disk failure, followed by an increase to the true value, once Volume Recovery recreates the lost streams that were previously on that the disk.
Info | |
---|---|
title | TipWhen youfirst boot yourbooting the cluster after installing or upgrading to version 9.0, Swarm starts traversing the volumes to build these statistics, so they willare not beaccurate until that completes; however, the value of the progression. Expect it to take 1 complete HP cycle to drop |
Usage via SNMP and REST
Swarm aggregates usage statistics from each volume and publishes them as cluster-wide values:
Aggregates | Units | Description | Accuracy |
---|---|---|---|
logicalObjects | count | The number of unique objects (including historical versions) stored for the entire cluster. Each content object counts only as 1, regardless of the number of replicas or EC segments that comprise it. | Approaches the actual number of logical objects in the cluster, minus context (domain, bucket) objects. |
NoteLogical counts are estimates, and they are not accurate during volume recovery. The estimating is a consequence of Swarm's robust, no-single-point-of-failure design: Swarm keeps no master list of objects, so counts are inferred from multiple overlapping sources of information. | |||
logicalSpace | MB | The logical space stored for the entire cluster, including historical versions (which are separate objects). | Includes both the data and the persisted headers on each object, with header newlines counting as two characters (‘\r\n’). EC encoded objects may include a small overage. |
---|---|---|---|
logicalUnprocessed | count | The number of streams in the cluster |
not |
accounted for in After implementation, it |
drops until it catches up, approaching zero. | When compared to the number of streams in the cluster, allows rough verification of other statistics, especially following the first boot after it is implemented. |
...
Note
These are cluster-level statistics, so each node is publishing the same values.
You can get Get logicalObjects
, logicalSpace
, and logicalUnprocessed
by polling a node using SNMP:
SNMP for usage
Code Block | ||||
---|---|---|---|---|
| ||||
snmpget -m +CARINGO-CASTOR-MIB -v2c -M +/usr/share/snmp/mib2c-data -cPASSWORD -OQs {node- ip} logicalSpace |
Alternatively, you can get Get logicalObjects
, logicalSpace
, and logicalUnprocessed
by polling a node using the REST API:
REST call for usage
Code Block | ||||
---|---|---|---|---|
| ||||
http://{node- ip}:91/api/storage/clusters/{clustername} |
Trends — : Each volume in a Swarm cluster is computing partial statistics for logical objects with replicas on other volumes. Swarm works to keep the correct number of replicas (and EC segments) for every object, but, if there are too many replicas, the statistics will trend higher. In the case of hardware failure, the statistics will trend lower while the recovery is taking place.
Timing — : Each volume has accurate partial statistics immediately after a write or delete. REST API statistics are immediately available after each volume broadcasts messages that are sent every 30 seconds, but SNMP adds up to another 60 seconds for periodic polling of the aggregated values. Metrics does not aggregate, so the periodic metrics reports will be is current with respect to the accounting cursor.
Usage via Metrics
Usage statistics are also reported via using Swarm's /wiki/spaces/DOCS/pages/2443813497 mechanism. These metrics are checked on demand, at query time. Although Swarm publishes the statistics under the volume metrics, be aware that the values represent the cluster level:
Volume Metrics | Units | Description |
---|---|---|
logical_objects | count | The number of unique objects (including historical versions) stored for the entire cluster. Each content object counts only as 1, regardless of the number of replicas or EC segments that comprise it. |
logical_space | bytes | The logical space stored for the entire cluster. The logical_space value is in bytes, not MB, for greater accuracy. |
logical_unprocessed | count | The number of streams (replicas, EC segments, etc.) in the cluster |
not |
counted for |