Struct k8s_openapi::api::core::v1::PersistentVolumeSpec
source · pub struct PersistentVolumeSpec {Show 31 fields
pub access_modes: Option<Vec<String>>,
pub aws_elastic_block_store: Option<AWSElasticBlockStoreVolumeSource>,
pub azure_disk: Option<AzureDiskVolumeSource>,
pub azure_file: Option<AzureFilePersistentVolumeSource>,
pub capacity: Option<BTreeMap<String, Quantity>>,
pub cephfs: Option<CephFSPersistentVolumeSource>,
pub cinder: Option<CinderPersistentVolumeSource>,
pub claim_ref: Option<ObjectReference>,
pub csi: Option<CSIPersistentVolumeSource>,
pub fc: Option<FCVolumeSource>,
pub flex_volume: Option<FlexPersistentVolumeSource>,
pub flocker: Option<FlockerVolumeSource>,
pub gce_persistent_disk: Option<GCEPersistentDiskVolumeSource>,
pub glusterfs: Option<GlusterfsPersistentVolumeSource>,
pub host_path: Option<HostPathVolumeSource>,
pub iscsi: Option<ISCSIPersistentVolumeSource>,
pub local: Option<LocalVolumeSource>,
pub mount_options: Option<Vec<String>>,
pub nfs: Option<NFSVolumeSource>,
pub node_affinity: Option<VolumeNodeAffinity>,
pub persistent_volume_reclaim_policy: Option<String>,
pub photon_persistent_disk: Option<PhotonPersistentDiskVolumeSource>,
pub portworx_volume: Option<PortworxVolumeSource>,
pub quobyte: Option<QuobyteVolumeSource>,
pub rbd: Option<RBDPersistentVolumeSource>,
pub scale_io: Option<ScaleIOPersistentVolumeSource>,
pub storage_class_name: Option<String>,
pub storageos: Option<StorageOSPersistentVolumeSource>,
pub volume_attributes_class_name: Option<String>,
pub volume_mode: Option<String>,
pub vsphere_volume: Option<VsphereVirtualDiskVolumeSource>,
}
Expand description
PersistentVolumeSpec is the specification of a persistent volume.
Fields§
§access_modes: Option<Vec<String>>
accessModes contains all ways the volume can be mounted. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes
aws_elastic_block_store: Option<AWSElasticBlockStoreVolumeSource>
awsElasticBlockStore represents an AWS Disk resource that is attached to a kubelet’s host machine and then exposed to the pod. More info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
azure_disk: Option<AzureDiskVolumeSource>
azureDisk represents an Azure Data Disk mount on the host and bind mount to the pod.
azure_file: Option<AzureFilePersistentVolumeSource>
azureFile represents an Azure File Service mount on the host and bind mount to the pod.
capacity: Option<BTreeMap<String, Quantity>>
capacity is the description of the persistent volume’s resources and capacity. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#capacity
cephfs: Option<CephFSPersistentVolumeSource>
cephFS represents a Ceph FS mount on the host that shares a pod’s lifetime
cinder: Option<CinderPersistentVolumeSource>
cinder represents a cinder volume attached and mounted on kubelets host machine. More info: https://examples.k8s.io/mysql-cinder-pd/README.md
claim_ref: Option<ObjectReference>
claimRef is part of a bi-directional binding between PersistentVolume and PersistentVolumeClaim. Expected to be non-nil when bound. claim.VolumeName is the authoritative bind between PV and PVC. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#binding
csi: Option<CSIPersistentVolumeSource>
csi represents storage that is handled by an external CSI driver (Beta feature).
fc: Option<FCVolumeSource>
fc represents a Fibre Channel resource that is attached to a kubelet’s host machine and then exposed to the pod.
flex_volume: Option<FlexPersistentVolumeSource>
flexVolume represents a generic volume resource that is provisioned/attached using an exec based plugin.
flocker: Option<FlockerVolumeSource>
flocker represents a Flocker volume attached to a kubelet’s host machine and exposed to the pod for its usage. This depends on the Flocker control service being running
gce_persistent_disk: Option<GCEPersistentDiskVolumeSource>
gcePersistentDisk represents a GCE Disk resource that is attached to a kubelet’s host machine and then exposed to the pod. Provisioned by an admin. More info: https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk
glusterfs: Option<GlusterfsPersistentVolumeSource>
glusterfs represents a Glusterfs volume that is attached to a host and exposed to the pod. Provisioned by an admin. More info: https://examples.k8s.io/volumes/glusterfs/README.md
host_path: Option<HostPathVolumeSource>
hostPath represents a directory on the host. Provisioned by a developer or tester. This is useful for single-node development and testing only! On-host storage is not supported in any way and WILL NOT WORK in a multi-node cluster. More info: https://kubernetes.io/docs/concepts/storage/volumes#hostpath
iscsi: Option<ISCSIPersistentVolumeSource>
iscsi represents an ISCSI Disk resource that is attached to a kubelet’s host machine and then exposed to the pod. Provisioned by an admin.
local: Option<LocalVolumeSource>
local represents directly-attached storage with node affinity
mount_options: Option<Vec<String>>
mountOptions is the list of mount options, e.g. [“ro”, “soft”]. Not validated - mount will simply fail if one is invalid. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes/#mount-options
nfs: Option<NFSVolumeSource>
nfs represents an NFS mount on the host. Provisioned by an admin. More info: https://kubernetes.io/docs/concepts/storage/volumes#nfs
node_affinity: Option<VolumeNodeAffinity>
nodeAffinity defines constraints that limit what nodes this volume can be accessed from. This field influences the scheduling of pods that use this volume.
persistent_volume_reclaim_policy: Option<String>
persistentVolumeReclaimPolicy defines what happens to a persistent volume when released from its claim. Valid options are Retain (default for manually created PersistentVolumes), Delete (default for dynamically provisioned PersistentVolumes), and Recycle (deprecated). Recycle must be supported by the volume plugin underlying this PersistentVolume. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#reclaiming
photon_persistent_disk: Option<PhotonPersistentDiskVolumeSource>
photonPersistentDisk represents a PhotonController persistent disk attached and mounted on kubelets host machine
portworx_volume: Option<PortworxVolumeSource>
portworxVolume represents a portworx volume attached and mounted on kubelets host machine
quobyte: Option<QuobyteVolumeSource>
quobyte represents a Quobyte mount on the host that shares a pod’s lifetime
rbd: Option<RBDPersistentVolumeSource>
rbd represents a Rados Block Device mount on the host that shares a pod’s lifetime. More info: https://examples.k8s.io/volumes/rbd/README.md
scale_io: Option<ScaleIOPersistentVolumeSource>
scaleIO represents a ScaleIO persistent volume attached and mounted on Kubernetes nodes.
storage_class_name: Option<String>
storageClassName is the name of StorageClass to which this persistent volume belongs. Empty value means that this volume does not belong to any StorageClass.
storageos: Option<StorageOSPersistentVolumeSource>
storageOS represents a StorageOS volume that is attached to the kubelet’s host machine and mounted into the pod More info: https://examples.k8s.io/volumes/storageos/README.md
volume_attributes_class_name: Option<String>
Name of VolumeAttributesClass to which this persistent volume belongs. Empty value is not allowed. When this field is not set, it indicates that this volume does not belong to any VolumeAttributesClass. This field is mutable and can be changed by the CSI driver after a volume has been updated successfully to a new class. For an unbound PersistentVolume, the volumeAttributesClassName will be matched with unbound PersistentVolumeClaims during the binding process. This is a beta field and requires enabling VolumeAttributesClass feature (off by default).
volume_mode: Option<String>
volumeMode defines if a volume is intended to be used with a formatted filesystem or to remain in raw block state. Value of Filesystem is implied when not included in spec.
vsphere_volume: Option<VsphereVirtualDiskVolumeSource>
vsphereVolume represents a vSphere volume attached and mounted on kubelets host machine
Trait Implementations§
source§impl Clone for PersistentVolumeSpec
impl Clone for PersistentVolumeSpec
source§fn clone(&self) -> PersistentVolumeSpec
fn clone(&self) -> PersistentVolumeSpec
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for PersistentVolumeSpec
impl Debug for PersistentVolumeSpec
source§impl DeepMerge for PersistentVolumeSpec
impl DeepMerge for PersistentVolumeSpec
source§fn merge_from(&mut self, other: Self)
fn merge_from(&mut self, other: Self)
other
into self
.source§impl Default for PersistentVolumeSpec
impl Default for PersistentVolumeSpec
source§fn default() -> PersistentVolumeSpec
fn default() -> PersistentVolumeSpec
source§impl<'de> Deserialize<'de> for PersistentVolumeSpec
impl<'de> Deserialize<'de> for PersistentVolumeSpec
source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
source§impl PartialEq for PersistentVolumeSpec
impl PartialEq for PersistentVolumeSpec
source§impl Serialize for PersistentVolumeSpec
impl Serialize for PersistentVolumeSpec
impl StructuralPartialEq for PersistentVolumeSpec
Auto Trait Implementations§
impl Freeze for PersistentVolumeSpec
impl RefUnwindSafe for PersistentVolumeSpec
impl Send for PersistentVolumeSpec
impl Sync for PersistentVolumeSpec
impl Unpin for PersistentVolumeSpec
impl UnwindSafe for PersistentVolumeSpec
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)