Storage aggregates endpoint overview
Retrieving storage aggregate information
The Storage Aggregate GET API retrieves all data aggregates in the cluster. System owned root aggregates are not included in the output. This API also supports specific queries, in addition to queries on aggregate body properties, which affect the output of the API. The parameters for these queries are "recommend" and "show_spares". Using the "recommend" query returns the list of aggregates that are recommended for creation in the cluster. The "show_spares" query returns a response outside of the records body, which includes the groups of usable spares in the cluster. The usable count for each class of spares does not include reserved spare capacity recommended by ONTAP best practices.
The collection GET returns the aggregate identifiers, UUID and name, and the node on which the aggregate resides. The instance GET, by default, returns all of the properties defined in the aggregates object, except advanced properties. The properties "space.footprint", "space.block_storage.inactive_user_data", and "space.block_storage.inactive_user_data_percent" are considered advanced properties and only returned when requested using the "fields" query parameter. Performance "metric" and "statistics" for aggregates are also only returned when requested. The "statistics" property accounts for the cumulative raw values collected by ONTAP for an aggregate, while the "metric" property displays the incremental average for latency and incremental changes in IOPs and throughput over the last 15 seconds. Any external application can use the raw statistics to derive its own incremental performance metrics. The collection GET does not support queries in conjunction with the "order_by" parameter.
Creating storage aggregates
When the POST command is issued with no properties, the system evaluates the cluster attached storage, determines the optimal aggregate layout and configures the aggregates. This layout is completely controlled by the system. To view the recommended optimal layout rather than creating it, use the GET endpoint, setting the "recommend" query to 'true'. This response will also include any warnings related to any inefficiencies in the storage configuration. Recommended aggregate creation is not supported on ONTAP Cloud and MetroCluster with Fibre Channel (FC). Alternatively, POST can be used with specific properties to create an aggregate as requested. At a minimum, the aggregate name, disk count, and the node where it should reside are required if any properties are provided.
When using POST with input properties, three properties are required. These are:
-
name
-
node.name or node.uuid
-
block_storage.primary.disk_count
Remaining properties are optional
The following properties can be specified in POST:
-
name - Name of the aggregate.
-
node.name and node.uuid - Node on which the aggregate will be created.
-
block_storage.primary.disk_count - Number of disks to be used to create the aggregate.
-
block_storage.mirror.enabled - Specifies whether or not the aggregate should be created using SyncMirror.
-
block_storage.primary.checksum_style - Checksum style of the disks to be use for the aggregate.
-
block_storage.primary.disk_class - Class of disks to be use to for the aggregate.
-
block_storage.primary.raid_size - Desired RAID size of the aggregate.
-
block_storage.primary.raid_type - Desired RAID type of the aggregate.
-
snaplock_type - SnapLock type to use on the aggregate.
-
data_encryption.software_encryption_enabled - Enable or disable NAE (NetApp Aggregate Encryption) on the aggregate.
Examples
Retrieving a list of aggregates from the cluster
The following example shows the response with a list of data aggregates in the cluster:
# The API: /api/storage/aggregates # The call: curl -X GET "https://<mgmt-ip>/api/storage/aggregates" -H "accept: application/json" # The response: { "records": [ { "uuid": "19425837-f2fa-4a9f-8f01-712f626c983c", "name": "test1", "node": { "uuid": "caf95bec-f801-11e8-8af9-005056bbe5c1", "name": "node-1", }, }, { "uuid": "4a7e4139-ca7a-420b-9a11-3f040d2189fd", "name": "test4", "node": { "uuid": "4046dda8-f802-11e8-8f6d-005056bb2030", "name": "node-2", }, } ], "num_records": 2, }
Retrieving a list of aggregates recommended for creation from the cluster
The following example shows the response with a list of recommended data aggregates in the cluster.
Each aggregate UUID provided in this response is not guaranteed to be the same UUID for the aggregate if it is created. |
# The API: /api/storage/aggregates # The call: curl -X GET "https://<mgmt-ip>/api/storage/aggregates?recommend=true&fields=*" -H "accept: application/json" # The response: { "records": [ { "uuid": "795bf7c2-fa4b-11e8-ba65-005056bbe5c1", "name": "node_2_SSD_1", "node": { "uuid": "4046dda8-f802-11e8-8f6d-005056bb2030", "name": "node-2", }, "space": { "block_storage": { "size": 1116180480 } }, "block_storage": { "primary": { "disk_count": 24, "disk_class": "solid_state", "raid_type": "raid_dp", "disk_type": "ssd", "raid_size": 24, "simulated_raid_groups": [ { "name": "rg0", "raid_type": "raid_dp", "parity_disk_count": 2, "data_disk_count": 10, "usable_size": 12309487, "is_partition": true }, { "name": "rg1", "raid_type": "raid_dp", "parity_disk_count": 2, "data_disk_count": 9, "usable_size": 12309487, "is_partition": false } ] }, "hybrid_cache": { "enabled": false }, "mirror": { "enabled": true } }, }, { "uuid": "795c0a15-fa4b-11e8-ba65-005056bbe5c1", "name": "node_1_SSD_1", "node": { "uuid": "caf95bec-f801-11e8-8af9-005056bbe5c1", "name": "node-1", }, "space": { "block_storage": { "size": 352477184 } }, "block_storage": { "primary": { "disk_count": 10, "disk_class": "solid_state", "raid_type": "raid_dp", "disk_type": "ssd", "raid_size": 24, "simulated_raid_groups": [ { "name": "rg0", "raid_type": "raid_dp", "parity_disk_count": 2, "data_disk_count": 10, "usable_size": 12309487, "is_partition": true }, { "name": "rg1", "raid_type": "raid_dp", "parity_disk_count": 2, "data_disk_count": 9, "usable_size": 12309487, "is_partition": false } ] }, "hybrid_cache": { "enabled": false }, "mirror": { "enabled": true } }, } ], "recommendation_spares" [ { "node": { "uuid": "795bf7c2-fa4b-11e8-ba65-005056bbe5cl", "name": "node-2", "_links": { "self" { "href": "/api/cluster/nodes/795bf7c2-fa4b-11e8-ba65-005056bbe5c1" } } }, "disk_class": "solid-state", "size": "2856845312", "is_partition": true, "disk_type": "ssd", "syncmirror_pool": "pool10", "usable": 1 } ], "num_records": 2, "warnings": [ { "name": "node_1_SSD_1", "warning": { "code": 19726347, "message": "Unable to use all attached capacity on node \"node_1\". 3 local/remote pool disks not usable for mirroring.", "arguments": [ "node_1", "3" ] }, "action": { "code": 19726348, "message": "Contact technical support." } }, { "name": "node_2_SSD_1", "warning": { "code": 19726347, "message": "Unable to use all attached capacity on node \"node_2\". 3 local/remote pool disks not usable for mirroring.", "arguments": [ "node_2", "3" ] }, "action": { "code": 19726348, "message": "Contact technical support." } } ], "_links": { "self": { "href": "/api/storage/aggregates?recommend=true&fields=*" } } }