-
Notifications
You must be signed in to change notification settings - Fork 270
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #466 from awels/dv_docs
Add Data Volume documentation
- Loading branch information
Showing
4 changed files
with
213 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,137 @@ | ||
# Data Volumes | ||
|
||
## Introduction | ||
Data Volumes(DV) are an abstraction on top of Persistent Volume Claims(PVC) and the Containerized Data Importer(CDI). The DV will monitor and orchestrate the upload/import of the data into the PVC. Once the process is completed, the DV will be in a consistent state that allow consumers to make certain assumptions about the DV in order to progress their own orchestration. | ||
|
||
Why is this an improvement over simply looking at the state annotation created and managed by CDI? Data Volumes provide a versioned API that other project like Kubevirt](https://github.com/kubevirt/kubevirt) can integrate with. This way those project can rely on an API staying the same for a particular version and have guarantees about what that API will look like. Any changes to the API will result in a new version of the API. | ||
|
||
### Status phases | ||
The following statuses are possible. | ||
* 'Blank': No status available. | ||
* Pending: The operation is pending, but has not been scheduled yet. | ||
* PVCBound: The PVC associated with the operation has been bound. | ||
* Import/Clone/UploadScheduled: The operation (import/clone/upload) has been scheduled. | ||
* Import/Clone/UploadInProgress: The operation (import/clone/upload) is in progress. | ||
* Succeeded: The operation has succeeded. | ||
* Failed: The operation has failed. | ||
* Unknown: Unknown status. | ||
|
||
## HTTP/S3 source | ||
Data Volumes are an abstraction on top of the annotations one can put on PVCs to trigger CDI. As such DVs have the notion of a 'source' that allows one to specify the source of the data. To import data from an external source, the source has to be either 'http' or 'S3'. If your source requires authentication, you can also pass in a secretRef to a Kubernetes [Secret](../manifest/example/endpoint-secret.yaml) containing the authentication information. | ||
|
||
```yaml | ||
apiVersion: cdi.kubevirt.io/v1alpha1 | ||
kind: DataVolume | ||
metadata: | ||
name: "example-import-dv" | ||
spec: | ||
source: | ||
http: | ||
url: "https://download.cirros-cloud.net/0.4.0/cirros-0.4.0-x86_64-disk.img" # Or S3 | ||
secretRef: "" # Optional | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: "64Mi" | ||
``` | ||
[Get example](../manifests/example/example-import-dv.yaml) | ||
[Get secret example](../manifest/example/endpoint-secret.yaml) | ||
## PVC source | ||
You can also use a PVC as an input source for a DV which will cause a clone to happen of the original PVC. You set the 'source' to be PVC, and specify the name and namespace of the PVC you want to have cloned. Be sure to specify the right amount of space to allocate for the new DV or the clone can't complete. | ||
```yaml | ||
apiVersion: cdi.kubevirt.io/v1alpha1 | ||
kind: DataVolume | ||
metadata: | ||
name: "example-clone-dv" | ||
spec: | ||
source: | ||
pvc: | ||
name: source-pvc | ||
namespace: example-ns | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: "128Mi" | ||
``` | ||
[Get example](../manifests/example/example-clone-dv.yaml) | ||
## Upload Data Volumes | ||
TBD, this has not been implemented yet. | ||
## Kubevirt integration | ||
[Kubevirt](https://github.com/kubevirt/kubevirt) is an extension to Kubernetes that allows one to run Virtual Machines(VM) on the same infra structure as the containers managed by Kubernetes. CDI provides a mechanism to get a disk image into a PVC in order for Kubevirt to consume it. The following steps have to be taken in order for Kubevirt to consume a CDI provided disk image. | ||
1. Create a PVC with an annotation to for instance import from an external URL. | ||
2. An importer pod is start that attempts to get the image from the external source. | ||
3. Create a VM definition that references the PVC we just created. | ||
4. Wait for the importer pod to finish (status can be checked by the status annotation on the PVC). | ||
5. Start the VMs using the imported disk. | ||
There is no mechanism to stop 5 from happening before the import is complete, so once can attempt to start the VM before the disk has been completely imported, with obvious bad results. | ||
Now lets do the same process but using DVs. | ||
1. Create a VM definition that references a DV template, which includes the external URL that contains the disk image. | ||
2. A DV is created from the template that in turn creates an underlying PVC with the correct annotation. | ||
3. The importer pod is created like before. | ||
4. Until the DV status is Success, the virt launcher controller will not schedule the VM to be launched if the user tries to start the VM. | ||
We now have a fully controlled mechanism where we can define a VM using a DV with a disk image from an external source, that cannot be scheduled to run until the import has been completed. | ||
### Example VM using DV | ||
```yaml | ||
apiVersion: kubevirt.io/v1alpha2 | ||
kind: VirtualMachine | ||
metadata: | ||
labels: | ||
kubevirt.io/vm: example-vm | ||
name: example-vm | ||
spec: | ||
dataVolumeTemplates: | ||
- metadata: | ||
name: example-dv | ||
spec: | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: 64Mi | ||
source: | ||
http: | ||
url: "https://download.cirros-cloud.net/0.4.0/cirros-0.4.0-x86_64-disk.img" | ||
running: false | ||
template: | ||
metadata: | ||
labels: | ||
kubevirt.io/vm: example-vm | ||
spec: | ||
domain: | ||
cpu: | ||
cores: 1 | ||
devices: | ||
disks: | ||
- disk: | ||
bus: virtio | ||
name: disk0 | ||
volumeName: example-datavolume | ||
machine: | ||
type: q35 | ||
resources: | ||
requests: | ||
memory: 64Mi | ||
terminationGracePeriodSeconds: 0 | ||
volumes: | ||
- dataVolume: | ||
name: example-dv | ||
name: example-datavolume | ||
``` | ||
[Get example](../manifests/example/example-vm-dv.yaml) | ||
This example combines all the different pieces into a single yaml. | ||
* Creation of a VM definition (example-vm) | ||
* Creation of a DV with a source of http which points to an external URL (example-dv) | ||
* Creation of a matching PVC with the same name as the DV, which will contain the result of the import (example-dv). | ||
* Creation of an importer pod that does the actual import work. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
apiVersion: cdi.kubevirt.io/v1alpha1 | ||
kind: DataVolume | ||
metadata: | ||
name: "example-clone-dv" | ||
spec: | ||
source: | ||
pvc: | ||
name: source-pvc | ||
namespace: example-ns | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: "128Mi" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
apiVersion: cdi.kubevirt.io/v1alpha1 | ||
kind: DataVolume | ||
metadata: | ||
name: "example-import-dv" | ||
spec: | ||
source: | ||
http: | ||
url: "https://download.cirros-cloud.net/0.4.0/cirros-0.4.0-x86_64-disk.img" # Or S3 | ||
secretRef: "" # Optional | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: "64Mi" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
apiVersion: kubevirt.io/v1alpha2 | ||
kind: VirtualMachine | ||
metadata: | ||
labels: | ||
kubevirt.io/vm: example-vm | ||
name: example-vm | ||
spec: | ||
dataVolumeTemplates: | ||
- metadata: | ||
name: example-dv | ||
spec: | ||
pvc: | ||
accessModes: | ||
- ReadWriteOnce | ||
resources: | ||
requests: | ||
storage: 64Mi | ||
source: | ||
http: | ||
url: "https://download.cirros-cloud.net/0.4.0/cirros-0.4.0-x86_64-disk.img" | ||
running: false | ||
template: | ||
metadata: | ||
labels: | ||
kubevirt.io/vm: example-vm | ||
spec: | ||
domain: | ||
cpu: | ||
cores: 1 | ||
devices: | ||
disks: | ||
- disk: | ||
bus: virtio | ||
name: disk0 | ||
volumeName: example-datavolume | ||
machine: | ||
type: q35 | ||
resources: | ||
requests: | ||
memory: 64Mi | ||
terminationGracePeriodSeconds: 0 | ||
volumes: | ||
- dataVolume: | ||
name: example-dv | ||
name: example-datavolume | ||
|