(storage-pure)= # Pure Storage - `pure` [Pure Storage](https://www.purestorage.com/) is a software-defined storage solution. It offers the consumption of redundant block storage across the network. LXD supports connecting to Pure Storage storage clusters through two protocols: either {abbr}`iSCSI (Internet Small Computer Systems Interface)` or {abbr}`NVMe/TCP (Non-Volatile Memory Express over Transmission Control Protocol)`. In addition, Pure Storage offers copy-on-write snapshots, thin provisioning, and other features. To use Pure Storage with LXD requires a Pure Storage API version of at least `2.21`, corresponding to a minimum Purity//FA version of `6.4.2`. Additionally, ensure that the required kernel modules for the selected protocol are installed on your host system. For iSCSI, the iSCSI CLI named `iscsiadm` needs to be installed in addition to the required kernel modules. ## Terminology Each storage pool created in LXD using a Pure Storage driver represents a Pure Storage *pod*, which is an abstraction that groups multiple volumes under a specific name. One benefit of using Pure Storage pods is that they can be linked with multiple Pure Storage arrays to provide additional redundancy. LXD creates volumes within a pod that is identified by the storage pool name. When the first volume needs to be mapped to a specific LXD host, a corresponding Pure Storage host is created with the name of the LXD host and a suffix of the used protocol. For example, if the LXD host is `host01` and the mode is `nvme`, the resulting Pure Storage host would be `host01-nvme`. The Pure Storage host is then connected with the required volumes, to allow attaching and accessing volumes from the LXD host. The created Pure Storage host is automatically removed once there are no volumes connected to it. ## The `pure` driver in LXD The `pure` driver in LXD uses Pure Storage volumes for custom storage volumes, instances, and snapshots. All created volumes are thin-provisioned block volumes. If required (for example, for containers and custom file system volumes), LXD formats the volume with a desired file system. LXD expects Pure Storage to be pre-configured with a specific service (e.g. iSCSI) on network interfaces whose address is provided during storage pool configuration. Furthermore, LXD assumes that it has full control over the Pure Storage pods it manages. Therefore, you should never maintain any volumes in Pure Storage pods that are not owned by LXD because LXD might disconnect or even delete them. This driver behaves differently than some of the other drivers in that it provides remote storage. As a result, and depending on the internal network, storage access might be a bit slower compared to local storage. On the other hand, using remote storage has significant advantages in a cluster setup: all cluster members have access to the same storage pools with the exact same contents, without the need to synchronize them. When creating a new storage pool using the `pure` driver in either `iscsi` or `nvme` mode, LXD automatically discovers the array's qualified name and target address (portal). Upon successful discovery, LXD attaches all volumes that are connected to the Pure Storage host that is associated with a specific LXD server. Pure Storage hosts and volume connections are fully managed by LXD. Volume snapshots are also supported by Pure Storage. However, each snapshot is associated with a parent volume and cannot be directly attached to the host. Therefore, when a snapshot is being exported, LXD creates a temporary volume behind the scenes. This volume is attached to the LXD host and removed once the operation is completed. Similarly, when a volume with at least one snapshot is being copied, LXD sequentially copies snapshots into destination volume, from which a new snapshot is created. Finally, once all snapshots are copied, the source volume is copied into the destination volume. (storage-pure-volume-names)= ### Volume names Due to a [limitation](storage-pure-limitations) in Pure Storage, volume names cannot exceed 63 characters. Therefore, the driver uses the volume's {config:option}`storage-pure-volume-conf:volatile.uuid` to generate a shorter volume name. For example, a UUID `5a2504b0-6a6c-4849-8ee7-ddb0b674fd14` is first trimmed of any hyphens (`-`), resulting in the string `5a2504b06a6c48498ee7ddb0b674fd14`. To distinguish volume types and snapshots, special identifiers are prepended and appended to the volume names, as depicted in the table below: Type | Identifier | Example :-- | :--- | :---------- Container | `c-` | `c-5a2504b06a6c48498ee7ddb0b674fd14` Virtual machine | `v-` | `v-5a2504b06a6c48498ee7ddb0b674fd14-b` (block volume) and `v-5a2504b06a6c48498ee7ddb0b674fd14` (file system volume) Image (ISO) | `i-` | `i-5a2504b06a6c48498ee7ddb0b674fd14-i` Custom volume | `u-` | `u-5a2504b06a6c48498ee7ddb0b674fd14` Snapshot | `s` | `sc-5a2504b06a6c48498ee7ddb0b674fd14` (container snapshot) (storage-pure-limitations)= ### Limitations The `pure` driver has the following limitations: Volume size constraints : Minimum volume size (quota) is `1MiB` and must be a multiple of `512B`. Snapshots cannot be mounted : Snapshots cannot be mounted directly to the host. Instead, a temporary volume must be created to access the snapshot's contents. For internal operations, such as copying instances or exporting snapshots, LXD handles this automatically. Sharing the Pure Storage storage pool between installations : Sharing the same Pure Storage storage pool between multiple LXD installations is not supported. If a different LXD installation tries to create a storage pool with a name that already exists, an error is returned. Recovering Pure Storage storage pools : Recovery of Pure Storage storage pools using `lxd recover` is currently not supported. ## Configuration options The following configuration options are available for storage pools that use the `pure` driver, as well as storage volumes in these pools. (storage-pure-pool-config)= ### Storage pool configuration % Include content from [../metadata.txt](../metadata.txt) ```{include} ../metadata.txt :start-after: :end-before: ``` {{volume_configuration}} (storage-pure-vol-config)= ### Storage volume configuration % Include content from [../metadata.txt](../metadata.txt) ```{include} ../metadata.txt :start-after: :end-before: ```