This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Questo contenuto non è disponibile nella lingua selezionata.
Chapter 5. Optimizing Storage
5.1. Overview
Optimizing storage helps to minimize storage use across all resources. By optimizing storage, administrators help ensure that existing storage resources are working in an efficient manner.
5.2. General Storage Guidelines
The following table lists the available persistent storage technologies for OpenShift Container Platform.
| Storage type | Description | Examples | 
|---|---|---|
| Block | 
 | CNS/CRS GlusterFS [a] iSCSI, Fibre Channel, Ceph RBD, OpenStack Cinder, AWS EBS [a], Dell/EMC Scale.IO, VMware vSphere Volume, GCE Persistent Disk [a], Azure Disk | 
| File | 
 | CNS/CRS GlusterFS [a], RHEL NFS, NetApp NFS [b] , Azure File, Vendor NFS, Vendor GlusterFS [c], Azure File, AWS EFS | 
| Object | 
 | CNS/CRS GlusterFS [a], Ceph Object Storage (RADOS Gateway), OpenStack Swift, Aliyun OSS, AWS S3, Google Cloud Storage, Azure Blob Storage, Vendor S3 [c], Vendor Swift [c] | 
| [a] 
									CNS/CRS GlusterFS, Ceph RBD, OpenStack Cinder, AWS EBS, Azure Disk, GCE persistent disk, and VMware vSphere support dynamic persistent volume (PV) provisioning natively in OpenShift Container Platform.
								 [b] 
									NetApp NFS supports dynamic PV provisioning when using the Trident plugin.
								 [c] 
									Vendor GlusterFS, Vendor S3, and Vendor Swift supportability and configurability may vary.
								 | ||
As of OpenShift Container Platform 3.6.1, Container-Native Storage (CNS) GlusterFS (a hyperconverged or cluster-hosted storage solution) and Container-Ready Storage (CRS) GlusterFS (an externally hosted storage solution) provides interfaces for block, file, and object storage for the purpose of the OpenShift Container Platform registry, logging, and metrics.
5.3. Storage Recommendations
The following table summarizes the recommended and configurable storage technologies for the given OpenShift Container Platform cluster application.
| Storage type | ROX [a] | RWX [b] | Registry | Scaled registry | Metrics | Logging | Apps | 
|---|---|---|---|---|---|---|---|
| Block | Yes [c] | No | Configurable | Not configurable | Recommended | Recommended | Recommended | 
| File | Yes [c] | Yes | Configurable | Configurable | Configurable | Configurable | Recommended | 
| Object | Yes | Yes | Recommended | Recommended | Not configurable | Not configurable | Not configurable [d] | 
| [a] 
								ReadOnlyMany
							 [b] 
								ReadWriteMany
							 [c] 
									This does not apply to physical disk, VM physical disk, VMDK, loopback over NFS, AWS EBS, and Azure Disk.
								 [d] 
									Object storage is not consumed through OpenShift Container Platform’s PVs/persistent volume claims (PVCs). Apps must integrate with the object storage REST API.
								 | |||||||
A scaled registry is an OpenShift Container Platform registry where three or more pod replicas are running.
5.3.1. Specific Application Storage Recommendations
5.3.1.1. Registry
In a non-scaled/high-availability (HA) OpenShift Container Platform registry cluster deployment:
- The preferred storage technology is object storage followed by block storage. The storage technology does not need to support RWX access mode.
- The storage technology must ensure read-after-write consistency. All NAS storage (excluding CNS/CRS GlusterFS as it uses an object storage interface) are not recommended for OpenShift Container Platform Registry cluster deployment with production workloads.
- 
								While hostPathvolumes are configurable for a non-scaled/HA OpenShift Container Platform Registry, they are not recommended for cluster deployment.
Corruption may occur when using NFS to back OpenShift Container Platform registry with production workloads.
5.3.1.2. Scaled Registry
In a scaled/HA OpenShift Container Platform registry cluster deployment:
- The preferred storage technology is object storage. The storage technology must support RWX access mode and must ensure read-after-write consistency.
- File storage and block storage are not recommended for a scaled/HA OpenShift Container Platform registry cluster deployment with production workloads.
- All NAS storage (excluding CNS/CRS GlusterFS as it uses an object storage interface) are not recommended for OpenShift Container Platform Registry cluster deployment with production workloads.
Corruption may occur when using NFS to back OpenShift Container Platform scaled/HA registry with production workloads.
5.3.1.3. Metrics
In an OpenShift Container Platform hosted metrics cluster deployment:
- The preferred storage technology is block storage.
- It is not recommended to use NAS storage (excluding CNS/CRS GlusterFS as it uses a block storage interface from iSCSI) for a hosted metrics cluster deployment with production workloads.
Corruption may occur when using NFS to back a hosted metrics cluster deployment with production workloads.
5.3.1.4. Logging
In an OpenShift Container Platform hosted logging cluster deployment:
- The preferred storage technology is block storage.
- It is not recommended to use NAS storage (excluding CNS/CRS GlusterFS as it uses a block storage interface from iSCSI) for a hosted metrics cluster deployment with production workloads.
Corruption may occur when using NFS to back hosted logging with production workloads.
5.3.1.5. Applications
Application use cases vary from application to application, as described in the following examples:
- Storage technologies that support dynamic PV provisioning have low mount time latencies, and are not tied to nodes to support a healthy cluster.
- NFS does not guarantee read-after-write consistency and is not recommended for applications which require it.
- Applications that depend on writing to the same, shared NFS export may experience issues with production workloads.
5.3.2. Other Specific Application Storage Recommendations
- OpenShift Container Platform Internal etcd: For the best etcd reliability, the lowest consistent latency storage technology is preferable.
- OpenStack Cinder: OpenStack Cinder tends to be adept in ROX access mode use cases.
- Databases: Databases (RDBMSs, NoSQL DBs, etc.) tend to perform best with dedicated block storage.
5.4. Choosing a Docker Graph Driver
Docker stores images and containers in a graph driver (a pluggable storage backend), such as Device Mapper, Overlay, and Btrfs. Each have advantages and disadvantages. For example, Overlay is faster than Device Mapper at starting and stopping containers, but is not POSIX compliant because of the architectural limitations of a union file system, and does not yet support SELinux.
For more information about Overlay, including supportability and usage caveats, see the RHEL 7.3 Release Notes.
In production environments, using a LVM thin pool on top of regular block devices (not loop devices) for container images and container root file systems storage is recommended.
Using a Loop device back-end can affect performance issues. While you can still continue to use it, Docker logs a warning message. For example:
devmapper: Usage of loopback devices is strongly discouraged for production use. Please use `--storage-opt dm.thinpooldev` or use `man docker` to refer to dm.thinpooldev section.
devmapper: Usage of loopback devices is strongly discouraged for production use.
Please use `--storage-opt dm.thinpooldev` or use `man docker` to refer to
dm.thinpooldev section.
				To ease Docker backend storage configuration, use the docker-storage-setup utility, which automates much of the configuration details:
			
- If you had a separate disk drive dedicated to Docker storage (for example, /dev/xvdb), add the following to the /etc/sysconfig/docker-storage-setup file: - DEVS=/dev/xvdb VG=docker_vg - DEVS=/dev/xvdb VG=docker_vg- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Restart the - docker-storage-setupservice:- systemctl restart docker-storage-setup - # systemctl restart docker-storage-setup- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the restart, - docker-storage-setupsets up a volume group named- docker_vgand creates a thin pool logical volume. Documentation for thin provisioning on RHEL is available in the LVM Administrator Guide. View the newly created volumes with the- lsblkcommand:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- Thin-provisioned volumes are not mounted and have no file system (individual containers do have an XFS file system), thus they will not show up in “df” output. 
- To verify that Docker is using a LVM thin pool, and to monitor disk space utilization, use the - docker infocommand. The- Pool Namewill correspond with the- VGyou specified in /etc/sysconfig/docker-storage-setup:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
				By default, a thin pool is configured to use 40% of the underlying block device. As you use the storage, LVM automatically extends the thin pool up to 100%. This is why the Data Space Total value does not match the full size of the underlying LVM device. This auto-extend technique was used to unify the storage approach taken in both Red Hat Enterprise Linux and Red Hat Atomic Host, which only uses a single partition.
			
In development, Docker in Red Hat distributions defaults to a loopback mounted sparse file. To see if your system is using the loopback mode:
docker info|grep loop0
# docker info|grep loop0
 Data file: /dev/loop0Red Hat strongly recommends using the Device Mapper storage driver in thin pool mode for production workloads.
Overlay is also supported for Docker use cases as of Red Hat Enterprise Linux 7.2, and provides faster start up time and page cache sharing, which can potentially improve density by reducing overall memory utilization.