maabara/manifests/longhorn/longhorn.yaml

5048 lines
172 KiB
YAML

---
# Builtin: "helm template" does not respect --create-namespace
apiVersion: v1
kind: Namespace
metadata:
name: longhorn-system
---
# Source: longhorn/templates/priorityclass.yaml
apiVersion: scheduling.k8s.io/v1
kind: PriorityClass
metadata:
name: "longhorn-critical"
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
description: "Ensure Longhorn pods have the highest priority to prevent any unexpected eviction by the Kubernetes scheduler under node pressure"
globalDefault: false
preemptionPolicy: PreemptLowerPriority
value: 1000000000
---
# Source: longhorn/templates/serviceaccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: longhorn-service-account
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
---
# Source: longhorn/templates/serviceaccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: longhorn-ui-service-account
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
---
# Source: longhorn/templates/serviceaccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: longhorn-support-bundle
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
---
# Source: longhorn/templates/default-setting.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: longhorn-default-setting
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
data:
default-setting.yaml: |-
priority-class: longhorn-critical
disable-revision-counter: true
---
# Source: longhorn/templates/storageclass.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: longhorn-storageclass
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
data:
storageclass.yaml: |
kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
name: longhorn
annotations:
storageclass.kubernetes.io/is-default-class: "true"
provisioner: driver.longhorn.io
allowVolumeExpansion: true
reclaimPolicy: "Delete"
volumeBindingMode: Immediate
parameters:
numberOfReplicas: "3"
staleReplicaTimeout: "30"
fromBackup: ""
fsType: "ext4"
dataLocality: "disabled"
unmapMarkSnapChainRemoved: "ignored"
disableRevisionCounter: "true"
dataEngine: "v1"
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backingimagedatasources.longhorn.io
spec:
group: longhorn.io
names:
kind: BackingImageDataSource
listKind: BackingImageDataSourceList
plural: backingimagedatasources
shortNames:
- lhbids
singular: backingimagedatasource
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The current state of the pod used to provision the backing image
file from source
jsonPath: .status.currentState
name: State
type: string
- description: The data source type
jsonPath: .spec.sourceType
name: SourceType
type: string
- description: The node the backing image file will be prepared on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk the backing image file will be prepared on
jsonPath: .spec.diskUUID
name: DiskUUID
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: BackingImageDataSource is where Longhorn stores backing image
data source object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The system generated UUID of the provisioned backing image file
jsonPath: .spec.uuid
name: UUID
type: string
- description: The current state of the pod used to provision the backing image
file from source
jsonPath: .status.currentState
name: State
type: string
- description: The data source type
jsonPath: .spec.sourceType
name: SourceType
type: string
- description: The backing image file size
jsonPath: .status.size
name: Size
type: string
- description: The node the backing image file will be prepared on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk the backing image file will be prepared on
jsonPath: .spec.diskUUID
name: DiskUUID
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: BackingImageDataSource is where Longhorn stores backing image
data source object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackingImageDataSourceSpec defines the desired state of the
Longhorn backing image data source
properties:
checksum:
type: string
diskPath:
type: string
diskUUID:
type: string
fileTransferred:
type: boolean
nodeID:
type: string
parameters:
additionalProperties:
type: string
type: object
sourceType:
enum:
- download
- upload
- export-from-volume
- restore
- clone
type: string
uuid:
type: string
type: object
status:
description: BackingImageDataSourceStatus defines the observed state of
the Longhorn backing image data source
properties:
checksum:
type: string
currentState:
type: string
ip:
type: string
message:
type: string
ownerID:
type: string
progress:
type: integer
runningParameters:
additionalProperties:
type: string
nullable: true
type: object
size:
format: int64
type: integer
storageIP:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backingimagemanagers.longhorn.io
spec:
group: longhorn.io
names:
kind: BackingImageManager
listKind: BackingImageManagerList
plural: backingimagemanagers
shortNames:
- lhbim
singular: backingimagemanager
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The current state of the manager
jsonPath: .status.currentState
name: State
type: string
- description: The image the manager pod will use
jsonPath: .spec.image
name: Image
type: string
- description: The node the manager is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk the manager is responsible for
jsonPath: .spec.diskUUID
name: DiskUUID
type: string
- description: The disk path the manager is using
jsonPath: .spec.diskPath
name: DiskPath
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: BackingImageManager is where Longhorn stores backing image manager
object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The current state of the manager
jsonPath: .status.currentState
name: State
type: string
- description: The image the manager pod will use
jsonPath: .spec.image
name: Image
type: string
- description: The node the manager is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk the manager is responsible for
jsonPath: .spec.diskUUID
name: DiskUUID
type: string
- description: The disk path the manager is using
jsonPath: .spec.diskPath
name: DiskPath
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: BackingImageManager is where Longhorn stores backing image manager
object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackingImageManagerSpec defines the desired state of the
Longhorn backing image manager
properties:
backingImages:
additionalProperties:
type: string
type: object
diskPath:
type: string
diskUUID:
type: string
image:
type: string
nodeID:
type: string
type: object
status:
description: BackingImageManagerStatus defines the observed state of the
Longhorn backing image manager
properties:
apiMinVersion:
type: integer
apiVersion:
type: integer
backingImageFileMap:
additionalProperties:
properties:
currentChecksum:
type: string
message:
type: string
name:
type: string
progress:
type: integer
senderManagerAddress:
type: string
sendingReference:
type: integer
size:
format: int64
type: integer
state:
type: string
uuid:
type: string
virtualSize:
format: int64
type: integer
type: object
nullable: true
type: object
currentState:
type: string
ip:
type: string
ownerID:
type: string
storageIP:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backingimages.longhorn.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
name: longhorn-conversion-webhook
namespace: longhorn-system
path: /v1/webhook/conversion
port: 9501
conversionReviewVersions:
- v1beta2
- v1beta1
group: longhorn.io
names:
kind: BackingImage
listKind: BackingImageList
plural: backingimages
shortNames:
- lhbi
singular: backingimage
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The backing image name
jsonPath: .spec.image
name: Image
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: BackingImage is where Longhorn stores backing image object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The system generated UUID
jsonPath: .status.uuid
name: UUID
type: string
- description: The source of the backing image file data
jsonPath: .spec.sourceType
name: SourceType
type: string
- description: The backing image file size in each disk
jsonPath: .status.size
name: Size
type: string
- description: The virtual size of the image (may be larger than file size)
jsonPath: .status.virtualSize
name: VirtualSize
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: BackingImage is where Longhorn stores backing image object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackingImageSpec defines the desired state of the Longhorn
backing image
properties:
checksum:
type: string
diskFileSpecMap:
additionalProperties:
properties:
evictionRequested:
type: boolean
type: object
type: object
diskSelector:
items:
type: string
type: array
disks:
additionalProperties:
type: string
description: Deprecated. We are now using DiskFileSpecMap to assign
different spec to the file on different disks.
type: object
minNumberOfCopies:
type: integer
nodeSelector:
items:
type: string
type: array
secret:
type: string
secretNamespace:
type: string
sourceParameters:
additionalProperties:
type: string
type: object
sourceType:
enum:
- download
- upload
- export-from-volume
- restore
- clone
type: string
type: object
status:
description: BackingImageStatus defines the observed state of the Longhorn
backing image status
properties:
checksum:
type: string
diskFileStatusMap:
additionalProperties:
properties:
lastStateTransitionTime:
type: string
message:
type: string
progress:
type: integer
state:
type: string
type: object
nullable: true
type: object
diskLastRefAtMap:
additionalProperties:
type: string
nullable: true
type: object
ownerID:
type: string
size:
format: int64
type: integer
uuid:
type: string
virtualSize:
description: Virtual size of image, which may be larger than physical
size. Will be zero until known (e.g. while a backing image is uploading)
format: int64
type: integer
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backupbackingimages.longhorn.io
spec:
group: longhorn.io
names:
kind: BackupBackingImage
listKind: BackupBackingImageList
plural: backupbackingimages
shortNames:
- lhbbi
singular: backupbackingimage
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The backing image name
jsonPath: .status.backingImage
name: BackingImage
type: string
- description: The backing image size
jsonPath: .status.size
name: Size
type: string
- description: The backing image backup upload finished time
jsonPath: .status.backupCreatedAt
name: BackupCreatedAt
type: string
- description: The backing image backup state
jsonPath: .status.state
name: State
type: string
- description: The last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: BackupBackingImage is where Longhorn stores backing image backup
object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackupBackingImageSpec defines the desired state of the Longhorn
backing image backup
properties:
labels:
additionalProperties:
type: string
description: The labels of backing image backup.
type: object
syncRequestedAt:
description: The time to request run sync the remote backing image
backup.
format: date-time
nullable: true
type: string
userCreated:
description: |-
Is this CR created by user through API or UI.
Required
type: boolean
required:
- userCreated
type: object
status:
description: BackupBackingImageStatus defines the observed state of the
Longhorn backing image backup
properties:
backingImage:
description: The backing image name.
type: string
backupCreatedAt:
description: The backing image backup upload finished time.
type: string
checksum:
description: The checksum of the backing image.
type: string
compressionMethod:
description: Compression method
type: string
error:
description: The error message when taking the backing image backup.
type: string
labels:
additionalProperties:
type: string
description: The labels of backing image backup.
nullable: true
type: object
lastSyncedAt:
description: The last time that the backing image backup was synced
with the remote backup target.
format: date-time
nullable: true
type: string
managerAddress:
description: The address of the backing image manager that runs backing
image backup.
type: string
messages:
additionalProperties:
type: string
description: The error messages when listing or inspecting backing
image backup.
nullable: true
type: object
ownerID:
description: The node ID on which the controller is responsible to
reconcile this CR.
type: string
progress:
description: The backing image backup progress.
type: integer
size:
description: The backing image size.
format: int64
type: integer
state:
description: |-
The backing image backup creation state.
Can be "", "InProgress", "Completed", "Error", "Unknown".
type: string
url:
description: The backing image backup URL.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backups.longhorn.io
spec:
group: longhorn.io
names:
kind: Backup
listKind: BackupList
plural: backups
shortNames:
- lhb
singular: backup
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The snapshot name
jsonPath: .status.snapshotName
name: SnapshotName
type: string
- description: The snapshot size
jsonPath: .status.size
name: SnapshotSize
type: string
- description: The snapshot creation time
jsonPath: .status.snapshotCreatedAt
name: SnapshotCreatedAt
type: string
- description: The backup state
jsonPath: .status.state
name: State
type: string
- description: The backup last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta1
schema:
openAPIV3Schema:
description: Backup is where Longhorn stores backup object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The snapshot name
jsonPath: .status.snapshotName
name: SnapshotName
type: string
- description: The snapshot size
jsonPath: .status.size
name: SnapshotSize
type: string
- description: The snapshot creation time
jsonPath: .status.snapshotCreatedAt
name: SnapshotCreatedAt
type: string
- description: The backup state
jsonPath: .status.state
name: State
type: string
- description: The backup last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: Backup is where Longhorn stores backup object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackupSpec defines the desired state of the Longhorn backup
properties:
backupMode:
description: |-
The backup mode of this backup.
Can be "full" or "incremental"
enum:
- full
- incremental
- ""
type: string
labels:
additionalProperties:
type: string
description: The labels of snapshot backup.
type: object
snapshotName:
description: The snapshot name.
type: string
syncRequestedAt:
description: The time to request run sync the remote backup.
format: date-time
nullable: true
type: string
type: object
status:
description: BackupStatus defines the observed state of the Longhorn backup
properties:
backupCreatedAt:
description: The snapshot backup upload finished time.
type: string
compressionMethod:
description: Compression method
type: string
error:
description: The error message when taking the snapshot backup.
type: string
labels:
additionalProperties:
type: string
description: The labels of snapshot backup.
nullable: true
type: object
lastSyncedAt:
description: The last time that the backup was synced with the remote
backup target.
format: date-time
nullable: true
type: string
messages:
additionalProperties:
type: string
description: The error messages when calling longhorn engine on listing
or inspecting backups.
nullable: true
type: object
newlyUploadDataSize:
description: Size in bytes of newly uploaded data
type: string
ownerID:
description: The node ID on which the controller is responsible to
reconcile this backup CR.
type: string
progress:
description: The snapshot backup progress.
type: integer
reUploadedDataSize:
description: Size in bytes of reuploaded data
type: string
replicaAddress:
description: The address of the replica that runs snapshot backup.
type: string
size:
description: The snapshot size.
type: string
snapshotCreatedAt:
description: The snapshot creation time.
type: string
snapshotName:
description: The snapshot name.
type: string
state:
description: |-
The backup creation state.
Can be "", "InProgress", "Completed", "Error", "Unknown".
type: string
url:
description: The snapshot backup URL.
type: string
volumeBackingImageName:
description: The volume's backing image name.
type: string
volumeCreated:
description: The volume creation time.
type: string
volumeName:
description: The volume name.
type: string
volumeSize:
description: The volume size.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backuptargets.longhorn.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
name: longhorn-conversion-webhook
namespace: longhorn-system
path: /v1/webhook/conversion
port: 9501
conversionReviewVersions:
- v1beta2
- v1beta1
group: longhorn.io
names:
kind: BackupTarget
listKind: BackupTargetList
plural: backuptargets
shortNames:
- lhbt
singular: backuptarget
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The backup target URL
jsonPath: .spec.backupTargetURL
name: URL
type: string
- description: The backup target credential secret
jsonPath: .spec.credentialSecret
name: Credential
type: string
- description: The backup target poll interval
jsonPath: .spec.pollInterval
name: LastBackupAt
type: string
- description: Indicate whether the backup target is available or not
jsonPath: .status.available
name: Available
type: boolean
- description: The backup target last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta1
schema:
openAPIV3Schema:
description: BackupTarget is where Longhorn stores backup target object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The backup target URL
jsonPath: .spec.backupTargetURL
name: URL
type: string
- description: The backup target credential secret
jsonPath: .spec.credentialSecret
name: Credential
type: string
- description: The backup target poll interval
jsonPath: .spec.pollInterval
name: LastBackupAt
type: string
- description: Indicate whether the backup target is available or not
jsonPath: .status.available
name: Available
type: boolean
- description: The backup target last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: BackupTarget is where Longhorn stores backup target object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackupTargetSpec defines the desired state of the Longhorn
backup target
properties:
backupTargetURL:
description: The backup target URL.
type: string
credentialSecret:
description: The backup target credential secret.
type: string
pollInterval:
description: The interval that the cluster needs to run sync with
the backup target.
type: string
syncRequestedAt:
description: The time to request run sync the remote backup target.
format: date-time
nullable: true
type: string
type: object
status:
description: BackupTargetStatus defines the observed state of the Longhorn
backup target
properties:
available:
description: Available indicates if the remote backup target is available
or not.
type: boolean
conditions:
description: Records the reason on why the backup target is unavailable.
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
lastSyncedAt:
description: The last time that the controller synced with the remote
backup target.
format: date-time
nullable: true
type: string
ownerID:
description: The node ID on which the controller is responsible to
reconcile this backup target CR.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: backupvolumes.longhorn.io
spec:
group: longhorn.io
names:
kind: BackupVolume
listKind: BackupVolumeList
plural: backupvolumes
shortNames:
- lhbv
singular: backupvolume
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The backup volume creation time
jsonPath: .status.createdAt
name: CreatedAt
type: string
- description: The backup volume last backup name
jsonPath: .status.lastBackupName
name: LastBackupName
type: string
- description: The backup volume last backup time
jsonPath: .status.lastBackupAt
name: LastBackupAt
type: string
- description: The backup volume last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta1
schema:
openAPIV3Schema:
description: BackupVolume is where Longhorn stores backup volume object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The backup volume creation time
jsonPath: .status.createdAt
name: CreatedAt
type: string
- description: The backup volume last backup name
jsonPath: .status.lastBackupName
name: LastBackupName
type: string
- description: The backup volume last backup time
jsonPath: .status.lastBackupAt
name: LastBackupAt
type: string
- description: The backup volume last synced time
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: BackupVolume is where Longhorn stores backup volume object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: BackupVolumeSpec defines the desired state of the Longhorn
backup volume
properties:
syncRequestedAt:
description: The time to request run sync the remote backup volume.
format: date-time
nullable: true
type: string
type: object
status:
description: BackupVolumeStatus defines the observed state of the Longhorn
backup volume
properties:
backingImageChecksum:
description: the backing image checksum.
type: string
backingImageName:
description: The backing image name.
type: string
createdAt:
description: The backup volume creation time.
type: string
dataStored:
description: The backup volume block count.
type: string
labels:
additionalProperties:
type: string
description: The backup volume labels.
nullable: true
type: object
lastBackupAt:
description: The latest volume backup time.
type: string
lastBackupName:
description: The latest volume backup name.
type: string
lastModificationTime:
description: The backup volume config last modification time.
format: date-time
nullable: true
type: string
lastSyncedAt:
description: The last time that the backup volume was synced into
the cluster.
format: date-time
nullable: true
type: string
messages:
additionalProperties:
type: string
description: The error messages when call longhorn engine on list
or inspect backup volumes.
nullable: true
type: object
ownerID:
description: The node ID on which the controller is responsible to
reconcile this backup volume CR.
type: string
size:
description: The backup volume size.
type: string
storageClassName:
description: the storage class name of pv/pvc binding with the volume.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: engineimages.longhorn.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
name: longhorn-conversion-webhook
namespace: longhorn-system
path: /v1/webhook/conversion
port: 9501
conversionReviewVersions:
- v1beta2
- v1beta1
group: longhorn.io
names:
kind: EngineImage
listKind: EngineImageList
plural: engineimages
shortNames:
- lhei
singular: engineimage
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: State of the engine image
jsonPath: .status.state
name: State
type: string
- description: The Longhorn engine image
jsonPath: .spec.image
name: Image
type: string
- description: Number of resources using the engine image
jsonPath: .status.refCount
name: RefCount
type: integer
- description: The build date of the engine image
jsonPath: .status.buildDate
name: BuildDate
type: date
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: EngineImage is where Longhorn stores engine image object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: Compatibility of the engine image
jsonPath: .status.incompatible
name: Incompatible
type: boolean
- description: State of the engine image
jsonPath: .status.state
name: State
type: string
- description: The Longhorn engine image
jsonPath: .spec.image
name: Image
type: string
- description: Number of resources using the engine image
jsonPath: .status.refCount
name: RefCount
type: integer
- description: The build date of the engine image
jsonPath: .status.buildDate
name: BuildDate
type: date
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: EngineImage is where Longhorn stores engine image object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: EngineImageSpec defines the desired state of the Longhorn
engine image
properties:
image:
minLength: 1
type: string
required:
- image
type: object
status:
description: EngineImageStatus defines the observed state of the Longhorn
engine image
properties:
buildDate:
type: string
cliAPIMinVersion:
type: integer
cliAPIVersion:
type: integer
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
controllerAPIMinVersion:
type: integer
controllerAPIVersion:
type: integer
dataFormatMinVersion:
type: integer
dataFormatVersion:
type: integer
gitCommit:
type: string
incompatible:
type: boolean
noRefSince:
type: string
nodeDeploymentMap:
additionalProperties:
type: boolean
nullable: true
type: object
ownerID:
type: string
refCount:
type: integer
state:
type: string
version:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: engines.longhorn.io
spec:
group: longhorn.io
names:
kind: Engine
listKind: EngineList
plural: engines
shortNames:
- lhe
singular: engine
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The current state of the engine
jsonPath: .status.currentState
name: State
type: string
- description: The node that the engine is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The instance manager of the engine
jsonPath: .status.instanceManagerName
name: InstanceManager
type: string
- description: The current image of the engine
jsonPath: .status.currentImage
name: Image
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: Engine is where Longhorn stores engine object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The data engine of the engine
jsonPath: .spec.dataEngine
name: Data Engine
type: string
- description: The current state of the engine
jsonPath: .status.currentState
name: State
type: string
- description: The node that the engine is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The instance manager of the engine
jsonPath: .status.instanceManagerName
name: InstanceManager
type: string
- description: The current image of the engine
jsonPath: .status.currentImage
name: Image
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Engine is where Longhorn stores engine object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: EngineSpec defines the desired state of the Longhorn engine
properties:
active:
type: boolean
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.
type: string
backupVolume:
type: string
dataEngine:
enum:
- v1
- v2
type: string
desireState:
type: string
disableFrontend:
type: boolean
engineImage:
description: 'Deprecated: Replaced by field `image`.'
type: string
frontend:
enum:
- blockdev
- iscsi
- nvmf
- ""
type: string
image:
type: string
logRequested:
type: boolean
nodeID:
type: string
replicaAddressMap:
additionalProperties:
type: string
type: object
requestedBackupRestore:
type: string
requestedDataSource:
type: string
revisionCounterDisabled:
type: boolean
salvageRequested:
type: boolean
snapshotMaxCount:
type: integer
snapshotMaxSize:
format: int64
type: string
unmapMarkSnapChainRemovedEnabled:
type: boolean
upgradedReplicaAddressMap:
additionalProperties:
type: string
type: object
volumeName:
type: string
volumeSize:
format: int64
type: string
type: object
status:
description: EngineStatus defines the observed state of the Longhorn engine
properties:
backupStatus:
additionalProperties:
properties:
backupURL:
type: string
error:
type: string
progress:
type: integer
replicaAddress:
type: string
snapshotName:
type: string
state:
type: string
type: object
nullable: true
type: object
cloneStatus:
additionalProperties:
properties:
error:
type: string
fromReplicaAddress:
type: string
isCloning:
type: boolean
progress:
type: integer
snapshotName:
type: string
state:
type: string
type: object
nullable: true
type: object
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
currentImage:
type: string
currentReplicaAddressMap:
additionalProperties:
type: string
nullable: true
type: object
currentSize:
format: int64
type: string
currentState:
type: string
endpoint:
type: string
instanceManagerName:
type: string
ip:
type: string
isExpanding:
type: boolean
lastExpansionError:
type: string
lastExpansionFailedAt:
type: string
lastRestoredBackup:
type: string
logFetched:
type: boolean
ownerID:
type: string
port:
type: integer
purgeStatus:
additionalProperties:
properties:
error:
type: string
isPurging:
type: boolean
progress:
type: integer
state:
type: string
type: object
nullable: true
type: object
rebuildStatus:
additionalProperties:
properties:
error:
type: string
fromReplicaAddress:
type: string
isRebuilding:
type: boolean
progress:
type: integer
state:
type: string
type: object
nullable: true
type: object
replicaModeMap:
additionalProperties:
type: string
nullable: true
type: object
replicaTransitionTimeMap:
additionalProperties:
type: string
description: |-
ReplicaTransitionTimeMap records the time a replica in ReplicaModeMap transitions from one mode to another (or
from not being in the ReplicaModeMap to being in it). This information is sometimes required by other controllers
(e.g. the volume controller uses it to determine the correct value for replica.Spec.lastHealthyAt).
type: object
restoreStatus:
additionalProperties:
properties:
backupURL:
type: string
currentRestoringBackup:
type: string
error:
type: string
filename:
type: string
isRestoring:
type: boolean
lastRestored:
type: string
progress:
type: integer
state:
type: string
type: object
nullable: true
type: object
salvageExecuted:
type: boolean
snapshotMaxCount:
type: integer
snapshotMaxSize:
format: int64
type: string
snapshots:
additionalProperties:
properties:
children:
additionalProperties:
type: boolean
nullable: true
type: object
created:
type: string
labels:
additionalProperties:
type: string
nullable: true
type: object
name:
type: string
parent:
type: string
removed:
type: boolean
size:
type: string
usercreated:
type: boolean
type: object
nullable: true
type: object
snapshotsError:
type: string
started:
type: boolean
storageIP:
type: string
unmapMarkSnapChainRemovedEnabled:
type: boolean
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: instancemanagers.longhorn.io
spec:
group: longhorn.io
names:
kind: InstanceManager
listKind: InstanceManagerList
plural: instancemanagers
shortNames:
- lhim
singular: instancemanager
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The state of the instance manager
jsonPath: .status.currentState
name: State
type: string
- description: The type of the instance manager (engine or replica)
jsonPath: .spec.type
name: Type
type: string
- description: The node that the instance manager is running on
jsonPath: .spec.nodeID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: InstanceManager is where Longhorn stores instance manager object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The data engine of the instance manager
jsonPath: .spec.dataEngine
name: Data Engine
type: string
- description: The state of the instance manager
jsonPath: .status.currentState
name: State
type: string
- description: The type of the instance manager (engine or replica)
jsonPath: .spec.type
name: Type
type: string
- description: The node that the instance manager is running on
jsonPath: .spec.nodeID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: InstanceManager is where Longhorn stores instance manager object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: InstanceManagerSpec defines the desired state of the Longhorn
instance manager
properties:
dataEngine:
type: string
image:
type: string
nodeID:
type: string
type:
enum:
- aio
- engine
- replica
type: string
type: object
status:
description: InstanceManagerStatus defines the observed state of the Longhorn
instance manager
properties:
apiMinVersion:
type: integer
apiVersion:
type: integer
currentState:
type: string
instanceEngines:
additionalProperties:
properties:
spec:
properties:
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.
type: string
dataEngine:
type: string
name:
type: string
type: object
status:
properties:
conditions:
additionalProperties:
type: boolean
nullable: true
type: object
endpoint:
type: string
errorMsg:
type: string
listen:
type: string
portEnd:
format: int32
type: integer
portStart:
format: int32
type: integer
resourceVersion:
format: int64
type: integer
state:
type: string
targetPortEnd:
format: int32
type: integer
targetPortStart:
format: int32
type: integer
type:
type: string
type: object
type: object
nullable: true
type: object
instanceReplicas:
additionalProperties:
properties:
spec:
properties:
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.
type: string
dataEngine:
type: string
name:
type: string
type: object
status:
properties:
conditions:
additionalProperties:
type: boolean
nullable: true
type: object
endpoint:
type: string
errorMsg:
type: string
listen:
type: string
portEnd:
format: int32
type: integer
portStart:
format: int32
type: integer
resourceVersion:
format: int64
type: integer
state:
type: string
targetPortEnd:
format: int32
type: integer
targetPortStart:
format: int32
type: integer
type:
type: string
type: object
type: object
nullable: true
type: object
instances:
additionalProperties:
properties:
spec:
properties:
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.
type: string
dataEngine:
type: string
name:
type: string
type: object
status:
properties:
conditions:
additionalProperties:
type: boolean
nullable: true
type: object
endpoint:
type: string
errorMsg:
type: string
listen:
type: string
portEnd:
format: int32
type: integer
portStart:
format: int32
type: integer
resourceVersion:
format: int64
type: integer
state:
type: string
targetPortEnd:
format: int32
type: integer
targetPortStart:
format: int32
type: integer
type:
type: string
type: object
type: object
description: 'Deprecated: Replaced by InstanceEngines and InstanceReplicas'
nullable: true
type: object
ip:
type: string
ownerID:
type: string
proxyApiMinVersion:
type: integer
proxyApiVersion:
type: integer
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: nodes.longhorn.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
name: longhorn-conversion-webhook
namespace: longhorn-system
path: /v1/webhook/conversion
port: 9501
conversionReviewVersions:
- v1beta2
- v1beta1
group: longhorn.io
names:
kind: Node
listKind: NodeList
plural: nodes
shortNames:
- lhn
singular: node
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: Indicate whether the node is ready
jsonPath: .status.conditions['Ready']['status']
name: Ready
type: string
- description: Indicate whether the user disabled/enabled replica scheduling for
the node
jsonPath: .spec.allowScheduling
name: AllowScheduling
type: boolean
- description: Indicate whether Longhorn can schedule replicas on the node
jsonPath: .status.conditions['Schedulable']['status']
name: Schedulable
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: Node is where Longhorn stores Longhorn node object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: Indicate whether the node is ready
jsonPath: .status.conditions[?(@.type=='Ready')].status
name: Ready
type: string
- description: Indicate whether the user disabled/enabled replica scheduling for
the node
jsonPath: .spec.allowScheduling
name: AllowScheduling
type: boolean
- description: Indicate whether Longhorn can schedule replicas on the node
jsonPath: .status.conditions[?(@.type=='Schedulable')].status
name: Schedulable
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Node is where Longhorn stores Longhorn node object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: NodeSpec defines the desired state of the Longhorn node
properties:
allowScheduling:
type: boolean
disks:
additionalProperties:
properties:
allowScheduling:
type: boolean
diskDriver:
enum:
- ""
- auto
- aio
type: string
diskType:
enum:
- filesystem
- block
type: string
evictionRequested:
type: boolean
path:
type: string
storageReserved:
format: int64
type: integer
tags:
items:
type: string
type: array
type: object
type: object
evictionRequested:
type: boolean
instanceManagerCPURequest:
type: integer
name:
type: string
tags:
items:
type: string
type: array
type: object
status:
description: NodeStatus defines the observed state of the Longhorn node
properties:
autoEvicting:
type: boolean
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
diskStatus:
additionalProperties:
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from
one status to another.
type: string
message:
description: Human-readable message indicating details
about last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the
condition's last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
diskDriver:
type: string
diskName:
type: string
diskPath:
type: string
diskType:
type: string
diskUUID:
type: string
filesystemType:
type: string
instanceManagerName:
type: string
scheduledReplica:
additionalProperties:
format: int64
type: integer
nullable: true
type: object
storageAvailable:
format: int64
type: integer
storageMaximum:
format: int64
type: integer
storageScheduled:
format: int64
type: integer
type: object
nullable: true
type: object
region:
type: string
snapshotCheckStatus:
properties:
lastPeriodicCheckedAt:
format: date-time
type: string
type: object
zone:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: orphans.longhorn.io
spec:
group: longhorn.io
names:
kind: Orphan
listKind: OrphanList
plural: orphans
shortNames:
- lho
singular: orphan
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The type of the orphan
jsonPath: .spec.orphanType
name: Type
type: string
- description: The node that the orphan is on
jsonPath: .spec.nodeID
name: Node
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: Orphan is where Longhorn stores orphan object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: OrphanSpec defines the desired state of the Longhorn orphaned
data
properties:
nodeID:
description: The node ID on which the controller is responsible to
reconcile this orphan CR.
type: string
orphanType:
description: |-
The type of the orphaned data.
Can be "replica".
type: string
parameters:
additionalProperties:
type: string
description: The parameters of the orphaned data
type: object
type: object
status:
description: OrphanStatus defines the observed state of the Longhorn orphaned
data
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
ownerID:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: recurringjobs.longhorn.io
spec:
group: longhorn.io
names:
kind: RecurringJob
listKind: RecurringJobList
plural: recurringjobs
shortNames:
- lhrj
singular: recurringjob
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: Sets groupings to the jobs. When set to "default" group will be
added to the volume label when no other job label exist in volume
jsonPath: .spec.groups
name: Groups
type: string
- description: Should be one of "backup" or "snapshot"
jsonPath: .spec.task
name: Task
type: string
- description: The cron expression represents recurring job scheduling
jsonPath: .spec.cron
name: Cron
type: string
- description: The number of snapshots/backups to keep for the volume
jsonPath: .spec.retain
name: Retain
type: integer
- description: The concurrent job to run by each cron job
jsonPath: .spec.concurrency
name: Concurrency
type: integer
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
- description: Specify the labels
jsonPath: .spec.labels
name: Labels
type: string
name: v1beta1
schema:
openAPIV3Schema:
description: RecurringJob is where Longhorn stores recurring job object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: Sets groupings to the jobs. When set to "default" group will be
added to the volume label when no other job label exist in volume
jsonPath: .spec.groups
name: Groups
type: string
- description: Should be one of "snapshot", "snapshot-force-create", "snapshot-cleanup",
"snapshot-delete", "backup", "backup-force-create" or "filesystem-trim"
jsonPath: .spec.task
name: Task
type: string
- description: The cron expression represents recurring job scheduling
jsonPath: .spec.cron
name: Cron
type: string
- description: The number of snapshots/backups to keep for the volume
jsonPath: .spec.retain
name: Retain
type: integer
- description: The concurrent job to run by each cron job
jsonPath: .spec.concurrency
name: Concurrency
type: integer
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
- description: Specify the labels
jsonPath: .spec.labels
name: Labels
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: RecurringJob is where Longhorn stores recurring job object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: RecurringJobSpec defines the desired state of the Longhorn
recurring job
properties:
concurrency:
description: The concurrency of taking the snapshot/backup.
type: integer
cron:
description: The cron setting.
type: string
groups:
description: The recurring job group.
items:
type: string
type: array
labels:
additionalProperties:
type: string
description: The label of the snapshot/backup.
type: object
name:
description: The recurring job name.
type: string
parameters:
additionalProperties:
type: string
description: |-
The parameters of the snapshot/backup.
Support parameters: "full-backup-interval".
type: object
retain:
description: The retain count of the snapshot/backup.
type: integer
task:
description: |-
The recurring job task.
Can be "snapshot", "snapshot-force-create", "snapshot-cleanup", "snapshot-delete", "backup", "backup-force-create" or "filesystem-trim"
enum:
- snapshot
- snapshot-force-create
- snapshot-cleanup
- snapshot-delete
- backup
- backup-force-create
- filesystem-trim
type: string
type: object
status:
description: RecurringJobStatus defines the observed state of the Longhorn
recurring job
properties:
executionCount:
description: The number of jobs that have been triggered.
type: integer
ownerID:
description: The owner ID which is responsible to reconcile this recurring
job CR.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: replicas.longhorn.io
spec:
group: longhorn.io
names:
kind: Replica
listKind: ReplicaList
plural: replicas
shortNames:
- lhr
singular: replica
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The current state of the replica
jsonPath: .status.currentState
name: State
type: string
- description: The node that the replica is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk that the replica is on
jsonPath: .spec.diskID
name: Disk
type: string
- description: The instance manager of the replica
jsonPath: .status.instanceManagerName
name: InstanceManager
type: string
- description: The current image of the replica
jsonPath: .status.currentImage
name: Image
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: Replica is where Longhorn stores replica object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The data engine of the replica
jsonPath: .spec.dataEngine
name: Data Engine
type: string
- description: The current state of the replica
jsonPath: .status.currentState
name: State
type: string
- description: The node that the replica is on
jsonPath: .spec.nodeID
name: Node
type: string
- description: The disk that the replica is on
jsonPath: .spec.diskID
name: Disk
type: string
- description: The instance manager of the replica
jsonPath: .status.instanceManagerName
name: InstanceManager
type: string
- description: The current image of the replica
jsonPath: .status.currentImage
name: Image
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Replica is where Longhorn stores replica object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: ReplicaSpec defines the desired state of the Longhorn replica
properties:
active:
type: boolean
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.
type: string
backingImage:
type: string
dataDirectoryName:
type: string
dataEngine:
enum:
- v1
- v2
type: string
desireState:
type: string
diskID:
type: string
diskPath:
type: string
engineImage:
description: 'Deprecated: Replaced by field `image`.'
type: string
engineName:
type: string
evictionRequested:
type: boolean
failedAt:
description: |-
FailedAt is set when a running replica fails or when a running engine is unable to use a replica for any reason.
FailedAt indicates the time the failure occurred. When FailedAt is set, a replica is likely to have useful
(though possibly stale) data. A replica with FailedAt set must be rebuilt from a non-failed replica (or it can
be used in a salvage if all replicas are failed). FailedAt is cleared before a rebuild or salvage. FailedAt may
be later than the corresponding entry in an engine's replicaTransitionTimeMap because it is set when the volume
controller acknowledges the change.
type: string
hardNodeAffinity:
type: string
healthyAt:
description: |-
HealthyAt is set the first time a replica becomes read/write in an engine after creation or rebuild. HealthyAt
indicates the time the last successful rebuild occurred. When HealthyAt is set, a replica is likely to have
useful (though possibly stale) data. HealthyAt is cleared before a rebuild. HealthyAt may be later than the
corresponding entry in an engine's replicaTransitionTimeMap because it is set when the volume controller
acknowledges the change.
type: string
image:
type: string
lastFailedAt:
description: |-
LastFailedAt is always set at the same time as FailedAt. Unlike FailedAt, LastFailedAt is never cleared.
LastFailedAt is not a reliable indicator of the state of a replica's data. For example, a replica with
LastFailedAt may already be healthy and in use again. However, because it is never cleared, it can be compared to
LastHealthyAt to help prevent dangerous replica deletion in some corner cases. LastFailedAt may be later than the
corresponding entry in an engine's replicaTransitionTimeMap because it is set when the volume controller
acknowledges the change.
type: string
lastHealthyAt:
description: |-
LastHealthyAt is set every time a replica becomes read/write in an engine. Unlike HealthyAt, LastHealthyAt is
never cleared. LastHealthyAt is not a reliable indicator of the state of a replica's data. For example, a
replica with LastHealthyAt set may be in the middle of a rebuild. However, because it is never cleared, it can be
compared to LastFailedAt to help prevent dangerous replica deletion in some corner cases. LastHealthyAt may be
later than the corresponding entry in an engine's replicaTransitionTimeMap because it is set when the volume
controller acknowledges the change.
type: string
logRequested:
type: boolean
nodeID:
type: string
rebuildRetryCount:
type: integer
revisionCounterDisabled:
type: boolean
salvageRequested:
type: boolean
snapshotMaxCount:
type: integer
snapshotMaxSize:
format: int64
type: string
unmapMarkDiskChainRemovedEnabled:
type: boolean
volumeName:
type: string
volumeSize:
format: int64
type: string
type: object
status:
description: ReplicaStatus defines the observed state of the Longhorn
replica
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
currentImage:
type: string
currentState:
type: string
evictionRequested:
description: 'Deprecated: Replaced by field `spec.evictionRequested`.'
type: boolean
instanceManagerName:
type: string
ip:
type: string
logFetched:
type: boolean
ownerID:
type: string
port:
type: integer
salvageExecuted:
type: boolean
started:
type: boolean
storageIP:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: settings.longhorn.io
spec:
group: longhorn.io
names:
kind: Setting
listKind: SettingList
plural: settings
shortNames:
- lhs
singular: setting
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The value of the setting
jsonPath: .value
name: Value
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: Setting is where Longhorn stores setting object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
value:
type: string
required:
- value
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The value of the setting
jsonPath: .value
name: Value
type: string
- description: The setting is applied
jsonPath: .status.applied
name: Applied
type: boolean
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Setting is where Longhorn stores setting object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
status:
description: The status of the setting.
properties:
applied:
description: The setting is applied.
type: boolean
required:
- applied
type: object
value:
description: The value of the setting.
type: string
required:
- value
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: sharemanagers.longhorn.io
spec:
group: longhorn.io
names:
kind: ShareManager
listKind: ShareManagerList
plural: sharemanagers
shortNames:
- lhsm
singular: sharemanager
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The state of the share manager
jsonPath: .status.state
name: State
type: string
- description: The node that the share manager is owned by
jsonPath: .status.ownerID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: ShareManager is where Longhorn stores share manager object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The state of the share manager
jsonPath: .status.state
name: State
type: string
- description: The node that the share manager is owned by
jsonPath: .status.ownerID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: ShareManager is where Longhorn stores share manager object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: ShareManagerSpec defines the desired state of the Longhorn
share manager
properties:
image:
description: Share manager image used for creating a share manager
pod
type: string
type: object
status:
description: ShareManagerStatus defines the observed state of the Longhorn
share manager
properties:
endpoint:
description: NFS endpoint that can access the mounted filesystem of
the volume
type: string
ownerID:
description: The node ID on which the controller is responsible to
reconcile this share manager resource
type: string
state:
description: The state of the share manager resource
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: snapshots.longhorn.io
spec:
group: longhorn.io
names:
kind: Snapshot
listKind: SnapshotList
plural: snapshots
shortNames:
- lhsnap
singular: snapshot
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The volume that this snapshot belongs to
jsonPath: .spec.volume
name: Volume
type: string
- description: Timestamp when the point-in-time snapshot was taken
jsonPath: .status.creationTime
name: CreationTime
type: string
- description: Indicates if the snapshot is ready to be used to restore/backup
a volume
jsonPath: .status.readyToUse
name: ReadyToUse
type: boolean
- description: Represents the minimum size of volume required to rehydrate from
this snapshot
jsonPath: .status.restoreSize
name: RestoreSize
type: string
- description: The actual size of the snapshot
jsonPath: .status.size
name: Size
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Snapshot is the Schema for the snapshots API
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: SnapshotSpec defines the desired state of Longhorn Snapshot
properties:
createSnapshot:
description: require creating a new snapshot
type: boolean
labels:
additionalProperties:
type: string
description: The labels of snapshot
nullable: true
type: object
volume:
description: |-
the volume that this snapshot belongs to.
This field is immutable after creation.
Required
type: string
required:
- volume
type: object
status:
description: SnapshotStatus defines the observed state of Longhorn Snapshot
properties:
checksum:
type: string
children:
additionalProperties:
type: boolean
nullable: true
type: object
creationTime:
type: string
error:
type: string
labels:
additionalProperties:
type: string
nullable: true
type: object
markRemoved:
type: boolean
ownerID:
type: string
parent:
type: string
readyToUse:
type: boolean
restoreSize:
format: int64
type: integer
size:
format: int64
type: integer
userCreated:
type: boolean
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: supportbundles.longhorn.io
spec:
group: longhorn.io
names:
kind: SupportBundle
listKind: SupportBundleList
plural: supportbundles
shortNames:
- lhbundle
singular: supportbundle
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The state of the support bundle
jsonPath: .status.state
name: State
type: string
- description: The issue URL
jsonPath: .spec.issueURL
name: Issue
type: string
- description: A brief description of the issue
jsonPath: .spec.description
name: Description
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: SupportBundle is where Longhorn stores support bundle object
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: SupportBundleSpec defines the desired state of the Longhorn
SupportBundle
properties:
description:
description: A brief description of the issue
type: string
issueURL:
description: The issue URL
nullable: true
type: string
nodeID:
description: The preferred responsible controller node ID.
type: string
required:
- description
type: object
status:
description: SupportBundleStatus defines the observed state of the Longhorn
SupportBundle
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
type: array
filename:
type: string
filesize:
format: int64
type: integer
image:
description: The support bundle manager image
type: string
managerIP:
description: The support bundle manager IP
type: string
ownerID:
description: The current responsible controller node ID
type: string
progress:
type: integer
state:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: systembackups.longhorn.io
spec:
group: longhorn.io
names:
kind: SystemBackup
listKind: SystemBackupList
plural: systembackups
shortNames:
- lhsb
singular: systembackup
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The system backup Longhorn version
jsonPath: .status.version
name: Version
type: string
- description: The system backup state
jsonPath: .status.state
name: State
type: string
- description: The system backup creation time
jsonPath: .status.createdAt
name: Created
type: string
- description: The last time that the system backup was synced into the cluster
jsonPath: .status.lastSyncedAt
name: LastSyncedAt
type: string
name: v1beta2
schema:
openAPIV3Schema:
description: SystemBackup is where Longhorn stores system backup object
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: SystemBackupSpec defines the desired state of the Longhorn
SystemBackup
properties:
volumeBackupPolicy:
description: |-
The create volume backup policy
Can be "if-not-present", "always" or "disabled"
nullable: true
type: string
type: object
status:
description: SystemBackupStatus defines the observed state of the Longhorn
SystemBackup
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
createdAt:
description: The system backup creation time.
format: date-time
type: string
gitCommit:
description: The saved Longhorn manager git commit.
nullable: true
type: string
lastSyncedAt:
description: The last time that the system backup was synced into
the cluster.
format: date-time
nullable: true
type: string
managerImage:
description: The saved manager image.
type: string
ownerID:
description: The node ID of the responsible controller to reconcile
this SystemBackup.
type: string
state:
description: The system backup state.
type: string
version:
description: The saved Longhorn version.
nullable: true
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: systemrestores.longhorn.io
spec:
group: longhorn.io
names:
kind: SystemRestore
listKind: SystemRestoreList
plural: systemrestores
shortNames:
- lhsr
singular: systemrestore
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The system restore state
jsonPath: .status.state
name: State
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: SystemRestore is where Longhorn stores system restore object
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: SystemRestoreSpec defines the desired state of the Longhorn
SystemRestore
properties:
systemBackup:
description: The system backup name in the object store.
type: string
required:
- systemBackup
type: object
status:
description: SystemRestoreStatus defines the observed state of the Longhorn
SystemRestore
properties:
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
ownerID:
description: The node ID of the responsible controller to reconcile
this SystemRestore.
type: string
sourceURL:
description: The source system backup URL.
type: string
state:
description: The system restore state.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: volumeattachments.longhorn.io
spec:
group: longhorn.io
names:
kind: VolumeAttachment
listKind: VolumeAttachmentList
plural: volumeattachments
shortNames:
- lhva
singular: volumeattachment
scope: Namespaced
versions:
- additionalPrinterColumns:
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: VolumeAttachment stores attachment information of a Longhorn
volume
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: VolumeAttachmentSpec defines the desired state of Longhorn
VolumeAttachment
properties:
attachmentTickets:
additionalProperties:
properties:
generation:
description: |-
A sequence number representing a specific generation of the desired state.
Populated by the system. Read-only.
format: int64
type: integer
id:
description: The unique ID of this attachment. Used to differentiate
different attachments of the same volume.
type: string
nodeID:
description: The node that this attachment is requesting
type: string
parameters:
additionalProperties:
type: string
description: Optional additional parameter for this attachment
type: object
type:
type: string
type: object
type: object
volume:
description: The name of Longhorn volume of this VolumeAttachment
type: string
required:
- volume
type: object
status:
description: VolumeAttachmentStatus defines the observed state of Longhorn
VolumeAttachment
properties:
attachmentTicketStatuses:
additionalProperties:
properties:
conditions:
description: Record any error when trying to fulfill this attachment
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from
one status to another.
type: string
message:
description: Human-readable message indicating details
about last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the
condition's last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
generation:
description: |-
A sequence number representing a specific generation of the desired state.
Populated by the system. Read-only.
format: int64
type: integer
id:
description: The unique ID of this attachment. Used to differentiate
different attachments of the same volume.
type: string
satisfied:
description: Indicate whether this attachment ticket has been
satisfied
type: boolean
required:
- conditions
- satisfied
type: object
type: object
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/crds.yaml
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.15.0
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
longhorn-manager: ""
name: volumes.longhorn.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
name: longhorn-conversion-webhook
namespace: longhorn-system
path: /v1/webhook/conversion
port: 9501
conversionReviewVersions:
- v1beta2
- v1beta1
group: longhorn.io
names:
kind: Volume
listKind: VolumeList
plural: volumes
shortNames:
- lhv
singular: volume
preserveUnknownFields: false
scope: Namespaced
versions:
- additionalPrinterColumns:
- description: The state of the volume
jsonPath: .status.state
name: State
type: string
- description: The robustness of the volume
jsonPath: .status.robustness
name: Robustness
type: string
- description: The scheduled condition of the volume
jsonPath: .status.conditions['scheduled']['status']
name: Scheduled
type: string
- description: The size of the volume
jsonPath: .spec.size
name: Size
type: string
- description: The node that the volume is currently attaching to
jsonPath: .status.currentNodeID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta1
schema:
openAPIV3Schema:
description: Volume is where Longhorn stores volume object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
x-kubernetes-preserve-unknown-fields: true
status:
x-kubernetes-preserve-unknown-fields: true
type: object
served: true
storage: false
subresources:
status: {}
- additionalPrinterColumns:
- description: The data engine of the volume
jsonPath: .spec.dataEngine
name: Data Engine
type: string
- description: The state of the volume
jsonPath: .status.state
name: State
type: string
- description: The robustness of the volume
jsonPath: .status.robustness
name: Robustness
type: string
- description: The scheduled condition of the volume
jsonPath: .status.conditions[?(@.type=='Schedulable')].status
name: Scheduled
type: string
- description: The size of the volume
jsonPath: .spec.size
name: Size
type: string
- description: The node that the volume is currently attaching to
jsonPath: .status.currentNodeID
name: Node
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
name: v1beta2
schema:
openAPIV3Schema:
description: Volume is where Longhorn stores volume object.
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: VolumeSpec defines the desired state of the Longhorn volume
properties:
Standby:
type: boolean
accessMode:
enum:
- rwo
- rwx
type: string
backendStoreDriver:
description: Deprecated:Replaced by field `dataEngine`.'
type: string
backingImage:
type: string
backupCompressionMethod:
enum:
- none
- lz4
- gzip
type: string
dataEngine:
enum:
- v1
- v2
type: string
dataLocality:
enum:
- disabled
- best-effort
- strict-local
type: string
dataSource:
type: string
disableFrontend:
type: boolean
diskSelector:
items:
type: string
type: array
encrypted:
type: boolean
engineImage:
description: 'Deprecated: Replaced by field `image`.'
type: string
freezeFilesystemForSnapshot:
description: Setting that freezes the filesystem on the root partition
before a snapshot is created.
enum:
- ignored
- enabled
- disabled
type: string
fromBackup:
type: string
frontend:
enum:
- blockdev
- iscsi
- nvmf
- ""
type: string
image:
type: string
lastAttachedBy:
type: string
migratable:
type: boolean
migrationNodeID:
type: string
nodeID:
type: string
nodeSelector:
items:
type: string
type: array
numberOfReplicas:
type: integer
replicaAutoBalance:
enum:
- ignored
- disabled
- least-effort
- best-effort
type: string
replicaDiskSoftAntiAffinity:
description: Replica disk soft anti affinity of the volume. Set enabled
to allow replicas to be scheduled in the same disk.
enum:
- ignored
- enabled
- disabled
type: string
replicaSoftAntiAffinity:
description: Replica soft anti affinity of the volume. Set enabled
to allow replicas to be scheduled on the same node.
enum:
- ignored
- enabled
- disabled
type: string
replicaZoneSoftAntiAffinity:
description: Replica zone soft anti affinity of the volume. Set enabled
to allow replicas to be scheduled in the same zone.
enum:
- ignored
- enabled
- disabled
type: string
restoreVolumeRecurringJob:
enum:
- ignored
- enabled
- disabled
type: string
revisionCounterDisabled:
type: boolean
size:
format: int64
type: string
snapshotDataIntegrity:
enum:
- ignored
- disabled
- enabled
- fast-check
type: string
snapshotMaxCount:
type: integer
snapshotMaxSize:
format: int64
type: string
staleReplicaTimeout:
type: integer
unmapMarkSnapChainRemoved:
enum:
- ignored
- disabled
- enabled
type: string
type: object
status:
description: VolumeStatus defines the observed state of the Longhorn volume
properties:
actualSize:
format: int64
type: integer
cloneStatus:
properties:
attemptCount:
type: integer
nextAllowedAttemptAt:
type: string
snapshot:
type: string
sourceVolume:
type: string
state:
type: string
type: object
conditions:
items:
properties:
lastProbeTime:
description: Last time we probed the condition.
type: string
lastTransitionTime:
description: Last time the condition transitioned from one status
to another.
type: string
message:
description: Human-readable message indicating details about
last transition.
type: string
reason:
description: Unique, one-word, CamelCase reason for the condition's
last transition.
type: string
status:
description: |-
Status is the status of the condition.
Can be True, False, Unknown.
type: string
type:
description: Type is the type of the condition.
type: string
type: object
nullable: true
type: array
currentImage:
type: string
currentMigrationNodeID:
description: the node that this volume is currently migrating to
type: string
currentNodeID:
type: string
expansionRequired:
type: boolean
frontendDisabled:
type: boolean
isStandby:
type: boolean
kubernetesStatus:
properties:
lastPVCRefAt:
type: string
lastPodRefAt:
type: string
namespace:
description: determine if PVC/Namespace is history or not
type: string
pvName:
type: string
pvStatus:
type: string
pvcName:
type: string
workloadsStatus:
description: determine if Pod/Workload is history or not
items:
properties:
podName:
type: string
podStatus:
type: string
workloadName:
type: string
workloadType:
type: string
type: object
nullable: true
type: array
type: object
lastBackup:
type: string
lastBackupAt:
type: string
lastDegradedAt:
type: string
ownerID:
type: string
pendingNodeID:
description: Deprecated.
type: string
remountRequestedAt:
type: string
restoreInitiated:
type: boolean
restoreRequired:
type: boolean
robustness:
type: string
shareEndpoint:
type: string
shareState:
type: string
state:
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
---
# Source: longhorn/templates/clusterrole.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: longhorn-role
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
rules:
- apiGroups:
- apiextensions.k8s.io
resources:
- customresourcedefinitions
verbs:
- "*"
- apiGroups: [""]
resources: ["pods", "events", "persistentvolumes", "persistentvolumeclaims","persistentvolumeclaims/status", "nodes", "proxy/nodes", "pods/log", "secrets", "services", "endpoints", "configmaps", "serviceaccounts"]
verbs: ["*"]
- apiGroups: [""]
resources: ["namespaces"]
verbs: ["get", "list"]
- apiGroups: ["apps"]
resources: ["daemonsets", "statefulsets", "deployments"]
verbs: ["*"]
- apiGroups: ["batch"]
resources: ["jobs", "cronjobs"]
verbs: ["*"]
- apiGroups: ["policy"]
resources: ["poddisruptionbudgets", "podsecuritypolicies"]
verbs: ["*"]
- apiGroups: ["scheduling.k8s.io"]
resources: ["priorityclasses"]
verbs: ["watch", "list"]
- apiGroups: ["storage.k8s.io"]
resources: ["storageclasses", "volumeattachments", "volumeattachments/status", "csinodes", "csidrivers"]
verbs: ["*"]
- apiGroups: ["snapshot.storage.k8s.io"]
resources: ["volumesnapshotclasses", "volumesnapshots", "volumesnapshotcontents", "volumesnapshotcontents/status"]
verbs: ["*"]
- apiGroups: ["longhorn.io"]
resources: ["volumes", "volumes/status", "engines", "engines/status", "replicas", "replicas/status", "settings", "settings/status",
"engineimages", "engineimages/status", "nodes", "nodes/status", "instancemanagers", "instancemanagers/status",
"sharemanagers", "sharemanagers/status", "backingimages", "backingimages/status",
"backingimagemanagers", "backingimagemanagers/status", "backingimagedatasources", "backingimagedatasources/status",
"backuptargets", "backuptargets/status", "backupvolumes", "backupvolumes/status", "backups", "backups/status",
"recurringjobs", "recurringjobs/status", "orphans", "orphans/status", "snapshots", "snapshots/status",
"supportbundles", "supportbundles/status", "systembackups", "systembackups/status", "systemrestores", "systemrestores/status",
"volumeattachments", "volumeattachments/status", "backupbackingimages", "backupbackingimages/status"]
verbs: ["*"]
- apiGroups: ["coordination.k8s.io"]
resources: ["leases"]
verbs: ["*"]
- apiGroups: ["metrics.k8s.io"]
resources: ["pods", "nodes"]
verbs: ["get", "list"]
- apiGroups: ["apiregistration.k8s.io"]
resources: ["apiservices"]
verbs: ["list", "watch"]
- apiGroups: ["admissionregistration.k8s.io"]
resources: ["mutatingwebhookconfigurations", "validatingwebhookconfigurations"]
verbs: ["get", "list", "create", "patch", "delete"]
- apiGroups: ["rbac.authorization.k8s.io"]
resources: ["roles", "rolebindings", "clusterrolebindings", "clusterroles"]
verbs: ["*"]
---
# Source: longhorn/templates/clusterrolebinding.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: longhorn-bind
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: longhorn-role
subjects:
- kind: ServiceAccount
name: longhorn-service-account
namespace: longhorn-system
---
# Source: longhorn/templates/clusterrolebinding.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: longhorn-support-bundle
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: longhorn-support-bundle
namespace: longhorn-system
---
# Source: longhorn/templates/daemonset-sa.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-manager
name: longhorn-backend
namespace: longhorn-system
spec:
type: ClusterIP
selector:
app: longhorn-manager
ports:
- name: manager
port: 9500
targetPort: manager
---
# Source: longhorn/templates/deployment-ui.yaml
kind: Service
apiVersion: v1
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-ui
name: longhorn-frontend
namespace: longhorn-system
spec:
type: ClusterIP
selector:
app: longhorn-ui
ports:
- name: http
port: 80
targetPort: http
nodePort: null
---
# Source: longhorn/templates/services.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-conversion-webhook
name: longhorn-conversion-webhook
namespace: longhorn-system
spec:
type: ClusterIP
selector:
longhorn.io/conversion-webhook: longhorn-conversion-webhook
ports:
- name: conversion-webhook
port: 9501
targetPort: conversion-wh
---
# Source: longhorn/templates/services.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-admission-webhook
name: longhorn-admission-webhook
namespace: longhorn-system
spec:
type: ClusterIP
selector:
longhorn.io/admission-webhook: longhorn-admission-webhook
ports:
- name: admission-webhook
port: 9502
targetPort: admission-wh
---
# Source: longhorn/templates/services.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-recovery-backend
name: longhorn-recovery-backend
namespace: longhorn-system
spec:
type: ClusterIP
selector:
longhorn.io/recovery-backend: longhorn-recovery-backend
ports:
- name: recovery-backend
port: 9503
targetPort: recov-backend
---
# Source: longhorn/templates/daemonset-sa.yaml
apiVersion: apps/v1
kind: DaemonSet
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-manager
name: longhorn-manager
namespace: longhorn-system
spec:
selector:
matchLabels:
app: longhorn-manager
template:
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-manager
spec:
containers:
- name: longhorn-manager
image: longhornio/longhorn-manager:v1.7.2
imagePullPolicy: IfNotPresent
securityContext:
privileged: true
command:
- longhorn-manager
- -d
- daemon
- --engine-image
- "longhornio/longhorn-engine:v1.7.2"
- --instance-manager-image
- "longhornio/longhorn-instance-manager:v1.7.2"
- --share-manager-image
- "longhornio/longhorn-share-manager:v1.7.2"
- --backing-image-manager-image
- "longhornio/backing-image-manager:v1.7.2"
- --support-bundle-manager-image
- "longhornio/support-bundle-kit:v0.0.45"
- --manager-image
- "longhornio/longhorn-manager:v1.7.2"
- --service-account
- longhorn-service-account
- --upgrade-version-check
ports:
- containerPort: 9500
name: manager
- containerPort: 9501
name: conversion-wh
- containerPort: 9502
name: admission-wh
- containerPort: 9503
name: recov-backend
readinessProbe:
httpGet:
path: /v1/healthz
port: 9501
scheme: HTTPS
volumeMounts:
- name: boot
mountPath: /host/boot/
- name: dev
mountPath: /host/dev/
- name: proc
mountPath: /host/proc/
- name: longhorn
mountPath: /var/lib/longhorn/
mountPropagation: Bidirectional
- name: longhorn-grpc-tls
mountPath: /tls-files/
env:
- name: POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: POD_IP
valueFrom:
fieldRef:
fieldPath: status.podIP
- name: NODE_NAME
valueFrom:
fieldRef:
fieldPath: spec.nodeName
- name: pre-pull-share-manager-image
imagePullPolicy: IfNotPresent
image: longhornio/longhorn-share-manager:v1.7.2
command: ["sh", "-c", "echo share-manager image pulled && sleep infinity"]
volumes:
- name: boot
hostPath:
path: /boot/
- name: dev
hostPath:
path: /dev/
- name: proc
hostPath:
path: /proc/
- name: longhorn
hostPath:
path: /var/lib/longhorn/
- name: longhorn-grpc-tls
secret:
secretName: longhorn-grpc-tls
optional: true
priorityClassName: "longhorn-critical"
serviceAccountName: longhorn-service-account
updateStrategy:
rollingUpdate:
maxUnavailable: "100%"
---
# Source: longhorn/templates/deployment-driver.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: longhorn-driver-deployer
namespace: longhorn-system
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
spec:
replicas: 1
selector:
matchLabels:
app: longhorn-driver-deployer
template:
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-driver-deployer
spec:
initContainers:
- name: wait-longhorn-manager
image: longhornio/longhorn-manager:v1.7.2
command: ['sh', '-c', 'while [ $(curl -m 1 -s -o /dev/null -w "%{http_code}" http://longhorn-backend:9500/v1) != "200" ]; do echo waiting; sleep 2; done']
containers:
- name: longhorn-driver-deployer
image: longhornio/longhorn-manager:v1.7.2
imagePullPolicy: IfNotPresent
command:
- longhorn-manager
- -d
- deploy-driver
- --manager-image
- "longhornio/longhorn-manager:v1.7.2"
- --manager-url
- http://longhorn-backend:9500/v1
env:
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: NODE_NAME
valueFrom:
fieldRef:
fieldPath: spec.nodeName
- name: SERVICE_ACCOUNT
valueFrom:
fieldRef:
fieldPath: spec.serviceAccountName
- name: CSI_ATTACHER_IMAGE
value: "longhornio/csi-attacher:v4.7.0"
- name: CSI_PROVISIONER_IMAGE
value: "longhornio/csi-provisioner:v4.0.1-20241007"
- name: CSI_NODE_DRIVER_REGISTRAR_IMAGE
value: "longhornio/csi-node-driver-registrar:v2.12.0"
- name: CSI_RESIZER_IMAGE
value: "longhornio/csi-resizer:v1.12.0"
- name: CSI_SNAPSHOTTER_IMAGE
value: "longhornio/csi-snapshotter:v7.0.2-20241007"
- name: CSI_LIVENESS_PROBE_IMAGE
value: "longhornio/livenessprobe:v2.14.0"
priorityClassName: "longhorn-critical"
serviceAccountName: longhorn-service-account
securityContext:
runAsUser: 0
---
# Source: longhorn/templates/deployment-ui.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-ui
name: longhorn-ui
namespace: longhorn-system
spec:
replicas: 2
selector:
matchLabels:
app: longhorn-ui
template:
metadata:
labels:
app.kubernetes.io/name: longhorn
app.kubernetes.io/instance: longhorn
app.kubernetes.io/version: v1.7.2
app: longhorn-ui
spec:
serviceAccountName: longhorn-ui-service-account
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
podAffinityTerm:
labelSelector:
matchExpressions:
- key: app
operator: In
values:
- longhorn-ui
topologyKey: kubernetes.io/hostname
containers:
- name: longhorn-ui
image: longhornio/longhorn-ui:v1.7.2
imagePullPolicy: IfNotPresent
volumeMounts:
- name : nginx-cache
mountPath: /var/cache/nginx/
- name : nginx-config
mountPath: /var/config/nginx/
- name: var-run
mountPath: /var/run/
ports:
- containerPort: 8000
name: http
env:
- name: LONGHORN_MANAGER_IP
value: "http://longhorn-backend:9500"
- name: LONGHORN_UI_PORT
value: "8000"
volumes:
- emptyDir: {}
name: nginx-cache
- emptyDir: {}
name: nginx-config
- emptyDir: {}
name: var-run
priorityClassName: "longhorn-critical"
---
# Source: longhorn/templates/validate-psp-install.yaml
#