Skip to content

Releases: vmware-tanzu/velero

v1.14.0-rc.3

14 Jun 09:20
2fc6300
Compare
Choose a tag to compare
v1.14.0-rc.3 Pre-release
Pre-release

v1.14

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.14.0

Container Image

velero/velero:v1.14.0

Documentation

https://velero.io/docs/v1.14/

Upgrading

https://velero.io/docs/v1.14/upgrade-to-1.14/

Highlights

The maintenance work for kopia/restic backup repositories is run in jobs

Since velero started using kopia as the approach for filesystem-level backup/restore, we've noticed an issue when velero connects to the kopia backup repositories and performs maintenance, it sometimes consumes excessive memory that can cause the velero pod to get OOM Killed. To mitigate this issue, the maintenance work will be moved out of velero pod to a separate kubernetes job, and the user will be able to specify the resource request in "velero install".

Volume Policies are extended to support more actions to handle volumes

In an earlier release, a flexible volume policy was introduced to skip certain volumes from a backup. In v1.14 we've made enhancement to this policy to allow the user to set how the volumes should be backed up. The user will be able to set "fs-backup" or "snapshot" as value of “action" in the policy and velero will backup the volumes accordingly. This enhancement allows the user to achieve a fine-grained control like "opt-in/out" without having to update the target workload. For more details please refer to https://velero.io/docs/v1.14/resource-filtering/#supported-volumepolicy-actions

Node Selection for Data Movement Backup

In velero the data movement flow relies on datamover pods, and these pods may take substantial resources and keep running for a long time. In v1.14, the user will be able to create a configmap to define the eligible nodes on which the datamover pods are launched. For more details refer to https://velero.io/docs/v1.14/data-movement-backup-node-selection/

VolumeInfo metadata for restored volumes

In v1.13, we introduced volumeinfo metadata for backup to help velero CLI and downstream adopter understand how velero handles each volume during backup. In v1.14, similar metadata will be persisted for each restore. velero CLI is also updated to bring more info in the output of "velero restore describe".

"Finalizing" phase is introduced to restores

The "Finalizing" phase is added to the state transition flow to restore, which helps us fix several issues: The labels added to PVs will be restored after the data in the PV is restored via volumesnapshotter. The post restore hook will be executed after datamovement is finished.

Certificate-based authentication support for Azure

Besides the service principal with secret(password)-based authentication, Velero introduces the new support for service principal with certificate-based authentication in v1.14.0. This approach enables you to adopt a phishing resistant authentication by using conditional access policies, which better protects Azure resources and is the recommended way by Azure.

Runtime and dependencies

  • Golang runtime: v1.22.2
  • kopia: v0.17.0

Limitations/Known issues

  • For the external BackupItemAction plugins that take snapshots for PVs, such as vsphere plugin. If the plugin checks the value of the field "snapshotVolumes" in the backup spec as a criteria for snapshot, the settings in the volume policy will not take effect. For example, if the "snapshotVolumes" is set to False in the backup spec, but a volume meets the condition in the volume policy for "snapshot" action, because the plugin will not check the settings in the volume policy, the plugin will not take snapshot for the volume. For more details please refer to #7818

Breaking changes

  • CSI plugin has been merged into velero repo in v1.14 release. It will be installed by default as an internal plugin, and should not be installed via "–plugins " parameter in "velero install" command.
  • The default resource requests and limitations for node agent are removed in v1.14, to make the node agent pods have the QoS class of "BestEffort", more details please refer to #7391
  • There's a change in namespace filtering behavior during backup: In v1.14, when the includedNamespaces/excludedNamespaces fields are not set and the labelSelector/OrLabelSelectors are set in the backup spec, the backup will only include the namespaces which contain the resources that match the label selectors, while in previous releases all namespaces will be included in the backup with such settings. More details refer to #7105
  • Patching the PV in the "Finalizing" state may cause the restore to be in "PartiallyFailed" state when the PV is blocked in "Pending" state, while in the previous release the restore may end up being in "Complete" state. For more details refer to #7866

All Changes

  • Fix backup log to show error string, not index (#7805, @piny940)
  • Modify the volume helper logic. (#7794, @blackpiglet)
  • Add documentation for extension of volume policy feature (#7779, @shubham-pampattiwar)
  • Surface errors when waiting for backupRepository and timeout occurs (#7762, @kaovilai)
  • Add existingResourcePolicy restore CR validation to controller (#7757, @kaovilai)
  • Fix condition matching in resource modifier when there are multiple rules (#7715, @27149chen)
  • Bump up the version of KinD and k8s in github actions (#7702, @reasonerjt)
  • Implementation for Extending VolumePolicies to support more actions (#7664, @shubham-pampattiwar)
  • Migrate from github.com/Azure/azure-storage-blob-go to github.com/Azure/azure-sdk-for-go/sdk/storage/azblob (#7598, @mmorel-35)
  • When Included/ExcludedNamespaces are omitted, and LabelSelector or OrLabelSelector is used, namespaces without selected items are excluded from backup. (#7697, @blackpiglet)
  • Display CSI snapshot restores in restore describe (#7687, @reasonerjt)
  • Use specific credential rather than the credential chain for Azure (#7680, @ywk253100)
  • Modify hook docs for clarity on displaying hook execution results (#7679, @allenxu404)
  • Wait for results of restore exec hook executions in Finalizing phase instead of InProgress phase (#7619, @allenxu404)
  • migrating to sdk/resourcemanager/**/arm** from services/**/mgmt/** (#7596, @mmorel-35)
  • Bump up to go1.22 (#7666, @reasonerjt)
  • Fix issue #7648. Adjust the exposing logic to avoid exposing failure and snapshot leak when expose fails (#7662, @Lyndon-Li)
  • Track and persist restore volume info (#7630, @reasonerjt)
  • Check the existence of the namespaces provided in the "--include-namespaces" option (#7569, @ywk253100)
  • Add the finalization phase to the restore workflow (#7377, @allenxu404)
  • Upgrade the version of go plugin related libs/tools (#7373, @ywk253100)
  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck. (#7322, @kaovilai)
  • Merge CSI plugin code into Velero. (#7609, @blackpiglet)
  • Fix issue #7391, remove the default constraint for node-agent pods (#7488, @Lyndon-Li)
  • Fix DataDownload fails during restore for empty PVC workload (#7521, @qiuming-best)
  • Add repository maintenance job (#7451, @qiuming-best)
  • Check whether the VolumeSnapshot's source PVC is nil before using it.
    Skip populate VolumeInfo for data-moved PV when CSI is not enabled. (#7515, @blackpiglet)
  • Fix issue #7308, change the data path requeue time to 5 second for data mover backup/restore, PVB and PVR. (#7458, @Lyndon-Li)
  • Patch newly dynamically provisioned PV with volume info to restore custom setting of PV (#7504, @allenxu404)
  • Adjust the logic for the backup_last_status metrics to stop incorrectly incrementing over time (#7445, @allenxu404)
  • dependabot: support github-actions updates (#7594, @mmorel-35)
  • Include the design for adding the finalization phase to the restore workflow (#7317, @allenxu404)
  • Fix issue #7211. Enable advanced feature capability and add support to concatenate objects for unified repo. (#7452, @Lyndon-Li)
  • Add design to introduce restore volume info (#7610, @reasonerjt)
  • Increase the k8s client QPS/burst to avoid throttling request errors (#7311, @ywk253100)
  • Support update the backup VolumeInfos by the Async ops result. (#7554, @blackpiglet)
  • FS backup create PodVolumeBackup when the backup excluded PVC,
    so I added logic to skip PVC volume type when PVC is not included in the backup resources to be backed up. (#7472, @sbahar619)
  • Respect and use credentialsFile specified in BSL.spec.config when IRSA is configured over Velero Pod Environment credentials (#7374, @reasonerjt)
  • Move the native snapshot definition code into internal directory (#7544, @blackpiglet)
  • Fix issue #7036. Add the implementation of node selection for data mover backups (#7437, @Lyndon-Li)
  • Fix issue #7535, add the MustHave resource check during item collection and item filter for restore (#7585, @Lyndon-Li)
  • build(deps): bump json-patch to v5.8.0 (#7584, @mmorel-35)
  • Add confirm flag to velero plugin add (#7566, @kaovilai)
  • do not skip unknown gvr at the beginning and get new gr when kind is changed (#7523, @27149chen)
  • Fix snapshot leak for backup (#7558, @qiuming-best)
  • For issue #7036, add the document for data mover node selection (#7640, @Lyndon-Li)
  • Add design for Extending VolumePolicies to support more actions (#6956, @shubham-pampattiwar)
  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7380, @kaovilai)
  • Improve the concurrency for PVBs in different pods (#7571, @ywk253100)
  • Bump up Kopia to v0.16.0 and open kopia repo with no index change (#7559, @Lyndon-Li)
  • Bump up the versions of several Kubernetes-related libs (#7489, @ywk253100)
  • Make parallel restore configurable (#7512, @qiuming-best)
  • Support certificate-based authentication for Azure (#7549, @ywk253100)
  • Fix issue #7281, batch delete snapshots in the same repo (#7438, @Lyndon-Li)
  • Add CRD name to error message when it is not ready to...
Read more

v1.14.0-rc.2

11 Jun 14:04
2136679
Compare
Choose a tag to compare
v1.14.0-rc.2 Pre-release
Pre-release

v1.14

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.14.0

Container Image

velero/velero:v1.14.0

Documentation

https://velero.io/docs/v1.14/

Upgrading

https://velero.io/docs/v1.14/upgrade-to-1.14/

Highlights

The maintenance work for kopia backup repositories is run in jobs

Since velero started using kopia as the approach for filesystem-level backup/restore, we've noticed an issue when velero connects to the kopia backup repositories and performs maintenance, it sometimes consumes excessive memory that can cause the velero pod to get OOM Killed. To mitigate this issue, the maintenance work will be moved out of velero pod to a separate kubernetes job, and the user will be able to specify the resource request in "velero install".

Volume Policies are extended to support more actions to handle volumes

In an earlier release, a flexible volume policy was introduced to skip certain volumes from a backup. In v1.14 we've made enhancement to this policy to allow the user to set how the volumes should be backed up. The user will be able to set "fs-backup" or "snapshot" as value of “action" in the policy and velero will backup the volumes accordingly. This enhancement allows the user to achieve a fine-grained control like "opt-in/out" without having to update the target workload. For more details please refer to https://velero.io/docs/v1.14/resource-filtering/#supported-volumepolicy-actions

Node Selection for Data Movement Backup

In velero the data movement flow relies on datamover pods, and these pods may take substantial resources and keep running for a long time. In v1.14, the user will be able to create a configmap to define the eligible nodes on which the datamover pods are launched. For more details refer to https://velero.io/docs/v1.14/data-movement-backup-node-selection/

VolumeInfo metadata for restored volumes

In v1.13, we introduced volumeinfo metadata for backup to help velero CLI and downstream adopter understand how velero handles each volume during backup. In v1.14, similar metadata will be persisted for each restore. velero CLI is also updated to bring more info in the output of "velero restore describe".

"Finalizing" phase is introduced to restores

The "Finalizing" phase is added to the state transition flow to restore, which helps us fix several issues: The labels added to PVs will be restored after the data in the PV is restored via volumesnapshotter. The post restore hook will be executed after datamovement is finished.

Certificate-based authentication support for Azure

Besides the service principal with secret(password)-based authentication, Velero introduces the new support for service principal with certificate-based authentication in v1.14.0. This approach enables you to adopt a phishing resistant authentication by using conditional access policies, which better protects Azure resources and is the recommended way by Azure.

Runtime and dependencies

  • Golang runtime: v1.22.2
  • kopia: v0.17.0

Limitations/Known issues

  • For the external BackupItemAction plugins that take snapshots for PVs, such as vsphere plugin. If the plugin checks the value of the field "snapshotVolumes" in the backup spec as a criteria for snapshot, the settings in the volume policy will not take effect. For example, if the "snapshotVolumes" is set to False in the backup spec, but a volume meets the condition in the volume policy for "snapshot" action, because the plugin will not check the settings in the volume policy, the plugin will not take snapshot for the volume. For more details please refer to #7818

Breaking changes

  • CSI plugin has been merged into velero repo in v1.14 release. It will be installed by default as an internal plugin, and should not be installed via "–plugins " parameter in "velero install" command.
  • The default resource requests and limitations for node agent are removed in v1.14, to make the node agent pods have the QoS class of "BestEffort", more details please refer to #7391
  • There's a change in namespace filtering behavior during backup: In v1.14, when the includedNamespaces/excludedNamespaces fields are not set and the labelSelector/OrLabelSelectors are set in the backup spec, the backup will only include the namespaces which contain the resources that match the label selectors, while in previous releases all namespaces will be included in the backup with such settings. More details refer to #7105
  • Patching the PV in the "finalizing" state may cause the restore to be in PartiallyFailed state when the PV is blocked in Pending state, while in the previous release the restore may end up being in Complete state for more details refer to #7866

All Changes

  • Fix backup log to show error string, not index (#7805, @piny940)
  • Modify the volume helper logic. (#7794, @blackpiglet)
  • Add documentation for extension of volume policy feature (#7779, @shubham-pampattiwar)
  • Surface errors when waiting for backupRepository and timeout occurs (#7762, @kaovilai)
  • Add existingResourcePolicy restore CR validation to controller (#7757, @kaovilai)
  • Fix condition matching in resource modifier when there are multiple rules (#7715, @27149chen)
  • Bump up the version of KinD and k8s in github actions (#7702, @reasonerjt)
  • Implementation for Extending VolumePolicies to support more actions (#7664, @shubham-pampattiwar)
  • Migrate from github.com/Azure/azure-storage-blob-go to github.com/Azure/azure-sdk-for-go/sdk/storage/azblob (#7598, @mmorel-35)
  • When Included/ExcludedNamespaces are omitted, and LabelSelector or OrLabelSelector is used, namespaces without selected items are excluded from backup. (#7697, @blackpiglet)
  • Display CSI snapshot restores in restore describe (#7687, @reasonerjt)
  • Use specific credential rather than the credential chain for Azure (#7680, @ywk253100)
  • Modify hook docs for clarity on displaying hook execution results (#7679, @allenxu404)
  • Wait for results of restore exec hook executions in Finalizing phase instead of InProgress phase (#7619, @allenxu404)
  • migrating to sdk/resourcemanager/**/arm** from services/**/mgmt/** (#7596, @mmorel-35)
  • Bump up to go1.22 (#7666, @reasonerjt)
  • Fix issue #7648. Adjust the exposing logic to avoid exposing failure and snapshot leak when expose fails (#7662, @Lyndon-Li)
  • Track and persist restore volume info (#7630, @reasonerjt)
  • Check the existence of the namespaces provided in the "--include-namespaces" option (#7569, @ywk253100)
  • Add the finalization phase to the restore workflow (#7377, @allenxu404)
  • Upgrade the version of go plugin related libs/tools (#7373, @ywk253100)
  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck. (#7322, @kaovilai)
  • Merge CSI plugin code into Velero. (#7609, @blackpiglet)
  • Fix issue #7391, remove the default constraint for node-agent pods (#7488, @Lyndon-Li)
  • Fix DataDownload fails during restore for empty PVC workload (#7521, @qiuming-best)
  • Add repository maintenance job (#7451, @qiuming-best)
  • Check whether the VolumeSnapshot's source PVC is nil before using it.
    Skip populate VolumeInfo for data-moved PV when CSI is not enabled. (#7515, @blackpiglet)
  • Fix issue #7308, change the data path requeue time to 5 second for data mover backup/restore, PVB and PVR. (#7458, @Lyndon-Li)
  • Patch newly dynamically provisioned PV with volume info to restore custom setting of PV (#7504, @allenxu404)
  • Adjust the logic for the backup_last_status metrics to stop incorrectly incrementing over time (#7445, @allenxu404)
  • dependabot: support github-actions updates (#7594, @mmorel-35)
  • Include the design for adding the finalization phase to the restore workflow (#7317, @allenxu404)
  • Fix issue #7211. Enable advanced feature capability and add support to concatenate objects for unified repo. (#7452, @Lyndon-Li)
  • Add design to introduce restore volume info (#7610, @reasonerjt)
  • Increase the k8s client QPS/burst to avoid throttling request errors (#7311, @ywk253100)
  • Support update the backup VolumeInfos by the Async ops result. (#7554, @blackpiglet)
  • FS backup create PodVolumeBackup when the backup excluded PVC,
    so I added logic to skip PVC volume type when PVC is not included in the backup resources to be backed up. (#7472, @sbahar619)
  • Respect and use credentialsFile specified in BSL.spec.config when IRSA is configured over Velero Pod Environment credentials (#7374, @reasonerjt)
  • Move the native snapshot definition code into internal directory (#7544, @blackpiglet)
  • Fix issue #7036. Add the implementation of node selection for data mover backups (#7437, @Lyndon-Li)
  • Fix issue #7535, add the MustHave resource check during item collection and item filter for restore (#7585, @Lyndon-Li)
  • build(deps): bump json-patch to v5.8.0 (#7584, @mmorel-35)
  • Add confirm flag to velero plugin add (#7566, @kaovilai)
  • do not skip unknown gvr at the beginning and get new gr when kind is changed (#7523, @27149chen)
  • Fix snapshot leak for backup (#7558, @qiuming-best)
  • For issue #7036, add the document for data mover node selection (#7640, @Lyndon-Li)
  • Add design for Extending VolumePolicies to support more actions (#6956, @shubham-pampattiwar)
  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7380, @kaovilai)
  • Improve the concurrency for PVBs in different pods (#7571, @ywk253100)
  • Bump up Kopia to v0.16.0 and open kopia repo with no index change (#7559, @Lyndon-Li)
  • Bump up the versions of several Kubernetes-related libs (#7489, @ywk253100)
  • Make parallel restore configurable (#7512, @qiuming-best)
  • Support certificate-based authentication for Azure (#7549, @ywk253100)
  • Fix issue #7281, batch delete snapshots in the same repo (#7438, @Lyndon-Li)
  • Add CRD name to error message when it is not ready to use (#...
Read more

v1.14.0-rc.1

27 May 10:32
952f713
Compare
Choose a tag to compare
v1.14.0-rc.1 Pre-release
Pre-release

v1.14

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.14.0

Container Image

velero/velero:v1.14.0

Documentation

https://velero.io/docs/v1.14/

Upgrading

https://velero.io/docs/v1.14/upgrade-to-1.14/

Highlights

The maintenance work for kopia/restic backup repositories is run in jobs

Since velero started using kopia as the approach for filesystem-level backup/restore, we've noticed an issue when velero connects to the kopia backup repositories and performs maintenance, it sometimes consumes excessive memory that can cause the velero pod to get OOM Killed. To mitigate this issue, the maintenance work will be moved out of velero pod to a separate kubernetes job, and the user will be able to specify the resource request in "velero install".

Volume Policies are extended to support more actions to handle volumes

In an earlier release, a flexible volume policy was introduced to skip certain volumes from a backup. In v1.14 we've made enhancement to this policy to allow the user to set how the volumes should be backed up. The user will be able to set "fs-backup" or "snapshot" as value of “action" in the policy and velero will backup the volumes accordingly. This enhancement allows the user to achieve a fine-grained control like "opt-in/out" without having to update the target workload. For more details please refer to https://velero.io/docs/v1.14/resource-filtering/#supported-volumepolicy-actions

Node Selection for Data Movement Backup

In velero the data movement flow relies on datamover pods, and these pods may take substantial resources and keep running for a long time. In v1.14, the user will be able to create a configmap to define the eligible nodes on which the datamover pods are launched. For more details refer to https://velero.io/docs/v1.14/data-movement-backup-node-selection/

VolumeInfo metadata for restored volumes

In v1.13, we introduced volumeinfo metadata for backup to help velero CLI and downstream adopter understand how velero handles each volume during backup. In v1.14, similar metadata will be persisted for each restore. velero CLI is also updated to bring more info in the output of "velero restore describe".

"Finalizing" phase is introduced to restores

The "Finalizing" phase is added to the state transition flow to restore, which helps us fix several issues: The labels added to PVs will be restored after the data in the PV is restored via volumesnapshotter. The post restore hook will be executed after datamovement is finished.

Certificate-based authentication support for Azure

Besides the service principal with secret(password)-based authentication, Velero introduces the new support for service principal with certificate-based authentication in v1.14.0. This approach enables you to adopt a phishing resistant authentication by using conditional access policies, which better protects Azure resources and is the recommended way by Azure.

Runtime and dependencies

  • Golang runtime: v1.22.2
  • kopia: v0.17.0

Limitations/Known issues

  • For the external BackupItemAction plugins that take snapshots for PVs, such as vsphere plugin. If the plugin checks the value of the field "snapshotVolumes" in the backup spec as a criteria for snapshot, the settings in the volume policy will not take effect. For example, if the "snapshotVolumes" is set to False in the backup spec, but a volume meets the condition in the volume policy for "snapshot" action, because the plugin will not check the settings in the volume policy, the plugin will not take snapshot for the volume. For more details please refer to #7818

Breaking changes

  • CSI plugin has been merged into velero repo in v1.14 release. It will be installed by default as an internal plugin, and should not be installed via "–plugins " parameter in "velero install" command.
  • The default resource requests and limitations for node agent are removed in v1.14, to make the node agent pods have the QoS class of "BestEffort", more details please refer to #7391
  • There's a change in namespace filtering behavior during backup: In v1.14, when the includedNamespaces/excludedNamespaces fields are not set and the labelSelector/OrLabelSelectors are set in the backup spec, the backup will only include the namespaces which contain the resources that match the label selectors, while in previous releases all namespaces will be included in the backup with such settings. More details refer to #7105

All Changes

  • Fix backup log to show error string, not index (#7805, @piny940)
  • Modify the volume helper logic. (#7794, @blackpiglet)
  • Add documentation for extension of volume policy feature (#7779, @shubham-pampattiwar)
  • Surface errors when waiting for backupRepository and timeout occurs (#7762, @kaovilai)
  • Add existingResourcePolicy restore CR validation to controller (#7757, @kaovilai)
  • Fix condition matching in resource modifier when there are multiple rules (#7715, @27149chen)
  • Bump up the version of KinD and k8s in github actions (#7702, @reasonerjt)
  • Implementation for Extending VolumePolicies to support more actions (#7664, @shubham-pampattiwar)
  • Migrate from github.com/Azure/azure-storage-blob-go to github.com/Azure/azure-sdk-for-go/sdk/storage/azblob (#7598, @mmorel-35)
  • When Included/ExcludedNamespaces are omitted, and LabelSelector or OrLabelSelector is used, namespaces without selected items are excluded from backup. (#7697, @blackpiglet)
  • Display CSI snapshot restores in restore describe (#7687, @reasonerjt)
  • Use specific credential rather than the credential chain for Azure (#7680, @ywk253100)
  • Modify hook docs for clarity on displaying hook execution results (#7679, @allenxu404)
  • Wait for results of restore exec hook executions in Finalizing phase instead of InProgress phase (#7619, @allenxu404)
  • migrating to sdk/resourcemanager/**/arm** from services/**/mgmt/** (#7596, @mmorel-35)
  • Bump up to go1.22 (#7666, @reasonerjt)
  • Fix issue #7648. Adjust the exposing logic to avoid exposing failure and snapshot leak when expose fails (#7662, @Lyndon-Li)
  • Track and persist restore volume info (#7630, @reasonerjt)
  • Check the existence of the namespaces provided in the "--include-namespaces" option (#7569, @ywk253100)
  • Add the finalization phase to the restore workflow (#7377, @allenxu404)
  • Upgrade the version of go plugin related libs/tools (#7373, @ywk253100)
  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck. (#7322, @kaovilai)
  • Merge CSI plugin code into Velero. (#7609, @blackpiglet)
  • Fix issue #7391, remove the default constraint for node-agent pods (#7488, @Lyndon-Li)
  • Fix DataDownload fails during restore for empty PVC workload (#7521, @qiuming-best)
  • Add repository maintenance job (#7451, @qiuming-best)
  • Check whether the VolumeSnapshot's source PVC is nil before using it.
    Skip populate VolumeInfo for data-moved PV when CSI is not enabled. (#7515, @blackpiglet)
  • Fix issue #7308, change the data path requeue time to 5 second for data mover backup/restore, PVB and PVR. (#7458, @Lyndon-Li)
  • Patch newly dynamically provisioned PV with volume info to restore custom setting of PV (#7504, @allenxu404)
  • Adjust the logic for the backup_last_status metrics to stop incorrectly incrementing over time (#7445, @allenxu404)
  • dependabot: support github-actions updates (#7594, @mmorel-35)
  • Include the design for adding the finalization phase to the restore workflow (#7317, @allenxu404)
  • Fix issue #7211. Enable advanced feature capability and add support to concatenate objects for unified repo. (#7452, @Lyndon-Li)
  • Add design to introduce restore volume info (#7610, @reasonerjt)
  • Increase the k8s client QPS/burst to avoid throttling request errors (#7311, @ywk253100)
  • Support update the backup VolumeInfos by the Async ops result. (#7554, @blackpiglet)
  • FS backup create PodVolumeBackup when the backup excluded PVC,
    so I added logic to skip PVC volume type when PVC is not included in the backup resources to be backed up. (#7472, @sbahar619)
  • Respect and use credentialsFile specified in BSL.spec.config when IRSA is configured over Velero Pod Environment credentials (#7374, @reasonerjt)
  • Move the native snapshot definition code into internal directory (#7544, @blackpiglet)
  • Fix issue #7036. Add the implementation of node selection for data mover backups (#7437, @Lyndon-Li)
  • Fix issue #7535, add the MustHave resource check during item collection and item filter for restore (#7585, @Lyndon-Li)
  • build(deps): bump json-patch to v5.8.0 (#7584, @mmorel-35)
  • Add confirm flag to velero plugin add (#7566, @kaovilai)
  • do not skip unknown gvr at the beginning and get new gr when kind is changed (#7523, @27149chen)
  • Fix snapshot leak for backup (#7558, @qiuming-best)
  • For issue #7036, add the document for data mover node selection (#7640, @Lyndon-Li)
  • Add design for Extending VolumePolicies to support more actions (#6956, @shubham-pampattiwar)
  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7380, @kaovilai)
  • Improve the concurrency for PVBs in different pods (#7571, @ywk253100)
  • Bump up Kopia to v0.16.0 and open kopia repo with no index change (#7559, @Lyndon-Li)
  • Bump up the versions of several Kubernetes-related libs (#7489, @ywk253100)
  • Make parallel restore configurable (#7512, @qiuming-best)
  • Support certificate-based authentication for Azure (#7549, @ywk253100)
  • Fix issue #7281, batch delete snapshots in the same repo (#7438, @Lyndon-Li)
  • Add CRD name to error message when it is not ready to use (#7295, @josemarevalo)
  • Add the design for node selection for data mover backup (#7383, @Lyndon-Li)
  • Bump up aws-sdk to latest version to leverage Pod Identity credentials. (#7307, @guikcd)
  • Fix issue #7246. Document the behavior for repo snaps...
Read more

v1.13.2

17 Apr 02:48
4d961fb
Compare
Choose a tag to compare

v1.13.2

2024-04-17

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.13.2

Container Image

velero/velero:v1.13.2

Documentation

https://velero.io/docs/v1.13/

Upgrading

https://velero.io/docs/v1.13/upgrade-to-1.13/

All changes

  • Bump up the versions of several Kubernetes-related libs (#7577, @ywk253100)
  • Fix issue #7535, add the MustHave resource check during item collection and item filter for restore (#7586, @Lyndon-Li)
  • Bump Golang version, and bump protobuf version (#7606, @blackpiglet)

v1.13.2-rc.1

15 Apr 07:16
4d961fb
Compare
Choose a tag to compare
v1.13.2-rc.1 Pre-release
Pre-release

v1.13.2-rc.1

2024-04-15

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.13.2-rc.1

Container Image

velero/velero:v1.13.2-rc.1

Documentation

https://velero.io/docs/v1.13/

Upgrading

https://velero.io/docs/v1.13/upgrade-to-1.13/

All changes

  • Bump up the versions of several Kubernetes-related libs (#7577, @ywk253100)
  • Fix issue #7535, add the MustHave resource check during item collection and item filter for restore (#7586, @Lyndon-Li)
  • Bump Golang version, and bump protobuf version (#7606, @blackpiglet)

v1.13.1

13 Mar 05:08
ea5a89f
Compare
Choose a tag to compare

v1.13.1

2024-03-13

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.13.1

Container Image

velero/velero:v1.13.1

Documentation

https://velero.io/docs/v1.13/

Upgrading

https://velero.io/docs/v1.13/upgrade-to-1.13/

All changes

  • Fix issue #7308, change the data path requeue time to 5 second for data mover backup/restore, PVB and PVR. (#7459, @Lyndon-Li)
  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7399, @kaovilai)
  • Adjust the logic for the backup_last_status metrics to stop incorrectly incrementing over time (#7445, @allenxu404)

v1.13.1-rc.1

11 Mar 03:40
ea5a89f
Compare
Choose a tag to compare
v1.13.1-rc.1 Pre-release
Pre-release

v1.13.1-rc.1

2024-03-11

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.13.1-rc.1

Container Image

velero/velero:v1.13.1-rc.1

Documentation

https://velero.io/docs/v1.13/

Upgrading

https://velero.io/docs/v1.13/upgrade-to-1.13/

All changes

  • Fix issue #7308, change the data path requeue time to 5 second for data mover backup/restore, PVB and PVR. (#7459, @Lyndon-Li)
  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7399, @kaovilai)
  • Adjust the logic for the backup_last_status metrics to stop incorrectly incrementing over time (#7445, @allenxu404)

v1.12.4

28 Feb 10:28
7d8417b
Compare
Choose a tag to compare

v1.12.4

2024-02-28

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.12.4

Container Image

velero/velero:v1.12.4

Documentation

https://velero.io/docs/v1.12/

Upgrading

https://velero.io/docs/v1.12/upgrade-to-1.12/

All changes

  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7397, @kaovilai)
  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck. (#7337, @kaovilai)
  • Make "disable-informer-cache" option false(enabled) by default to keep it consistent with the help message (#7298, @ywk253100)
  • Add description markers for dataupload and datadownload CRDs (#7042, @shubham-pampattiwar)

v1.12.4-rc.1

26 Feb 09:42
7d8417b
Compare
Choose a tag to compare
v1.12.4-rc.1 Pre-release
Pre-release

v1.12.4-rc.1

2024-02-26

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.12.4-rc.1

Container Image

velero/velero:v1.12.4-rc.1

Documentation

https://velero.io/docs/v1.12/

Upgrading

https://velero.io/docs/v1.12/upgrade-to-1.12/

All changes

  • BackupRepositories associated with a BSL are invalidated when BSL is (re-)created. (#7397, @kaovilai)
  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck. (#7337, @kaovilai)
  • Make "disable-informer-cache" option false(enabled) by default to keep it consistent with the help message (#7298, @ywk253100)
  • Add description markers for dataupload and datadownload CRDs (#7042, @shubham-pampattiwar)

v1.13.0

29 Jan 08:31
76670e9
Compare
Choose a tag to compare

v1.13

2024-01-29

Download

https://github.com/vmware-tanzu/velero/releases/tag/v1.13.0

Container Image

velero/velero:v1.13.0

Documentation

https://velero.io/docs/v1.13/

Upgrading

https://velero.io/docs/v1.13/upgrade-to-1.13/

Highlights

Resource Modifier Enhancement

Velero introduced the Resource Modifiers in v1.12.0. This feature allows users to specify a ConfigMap with a set of rules to modify the resources during restoration. However, only the JSON Patch is supported when creating the rules, and JSON Patch has some limitations, which cannot cover all use cases. In v1.13.0, Velero adds new support for JSON Merge Patch and Strategic Merge Patch, which provide more power and flexibility and allow users to use the same ConfigMap to apply patches on the resources. More design details can be found in Support JSON Merge Patch and Strategic Merge Patch in Resource Modifiers design. For instructions on how to use the feature, please refer to the Resource Modifiers doc.

Node-Agent Concurrency

Velero data movement activities from fs-backups and CSI snapshot data movements run in Velero node-agent, so may be hosted by every node in the cluster and consume resources (i.e. CPU, memory, network bandwidth) from there. With v1.13, users are allowed to configure how many data movement activities (a.k.a, loads) run in each node globally or by node, so that users can better leverage the performance of Velero data movement activities and the resource consumption in the cluster. For more information, check the Node-Agent Concurrency document.

Parallel Files Upload Options

Velero now supports configurable options for parallel files upload when using Kopia uploader to do fs-backups or CSI snapshot data movements which makes speed up backup possible.
For more information, please check Here.

Write Sparse Files Options

If using fs-restore or CSI snapshot data movements, it’s supported to write sparse files during restore. For more information, please check Here.

Backup Describe

In v1.13, the Backup Volume section is added to the velero backup describe command output. The backup Volumes section describes information for all the volumes included in the backup of various backup types, i.e. native snapshot, fs-backup, CSI snapshot, and CSI snapshot data movement. Particularly, the velero backup description now supports showing the information of CSI snapshot data movements, which is not supported in v1.12.

Additionally, backup describe command will not check EnableCSI feature gate from client side, so if a backup has volumes with CSI snapshot or CSI snapshot data movement, backup describe command always shows the corresponding information in its output.

Backup's new VolumeInfo metadata

Create a new metadata file in the backup repository's backup name sub-directory to store the backup-including PVC and PV information. The information includes the backing-up method of the PVC and PV data, snapshot information, and status. The VolumeInfo metadata file determines how the PV resource should be restored. The Velero downstream software can also use this metadata file to get a summary of the backup's volume data information.

Enhancement for CSI Snapshot Data Movements when Velero Pod Restart

When performing backup and restore operations, enhancements have been implemented for Velero server pods or node agents to ensure that the current backup or restore process is not stuck or interrupted after restart due to certain exceptional circumstances.

New status fields added to show hook execution details

Hook execution status is now included in the backup/restore CR status and displayed in the backup/restore describe command output. Specifically, it will show the number of hooks which attempted to execute under the HooksAttempted field and the number of hooks which failed to execute under the HooksFailed field.

AWS SDK Bump Up

Bump up AWS SDK for Go to version 2, which offers significant performance improvements in CPU and memory utilization over version 1.

Azure AD/Workload Identity Support

Azure AD/Workload Identity is the recommended approach to do the authentication with Azure services/AKS, Velero has introduced support for Azure AD/Workload Identity on the Velero Azure plugin side in previous releases, and in v1.13.0 Velero adds new support for Kopia operations(file system backup/data mover/etc.) with Azure AD/Workload Identity.

Runtime and dependencies

To fix CVEs and keep pace with Golang, Velero made changes as follows:

  • Bump Golang runtime to v1.21.6.
  • Bump several dependent libraries to new versions.
  • Bump Kopia to v0.15.0.

Breaking changes

  • Backup describe command: due to the backup describe output enhancement, some existing information (i.e. the output for native snapshot, CSI snapshot, and fs-backup) has been moved to the Backup Volumes section with some format changes.
  • API type changes: changes the field DataMoverConfig in DataUploadSpec from *map[string][string]`` to map[string]string`
  • Velero install command: due to the issue #7264, v1.13.0 introduces a break change that make the informer cache enabled by default to keep the actual behavior consistent with the helper message(the informer cache is disabled by default before the change).

Limitations/Known issues

  • The backup's VolumeInfo metadata doesn't have the information updated in the async operations. This function could be supported in v1.14 release.

Note

  • Velero introduces the informer cache which is enabled by default. The informer cache improves the restore performance but may cause higher memory consumption. Increase the memory limit of the Velero pod or disable the informer cache by specifying the --disable-informer-cache option when installing Velero if you get the OOM error.

Deprecation announcement

  • The generated k8s clients, informers, and listers are deprecated in the Velero v1.13 release. They are put in the Velero repository's pkg/generated directory. According to the n+2 supporting policy, the deprecated are kept for two more releases. The pkg/generated directory should be deleted in the v1.15 release.
  • After the backup VolumeInfo metadata file is added to the backup, Velero decides how to restore the PV resource according to the VolumeInfo content. To support the backup generated by the older version of Velero, the old logic is also kept. The support for the backup without the VolumeInfo metadata file will be kept for two releases. The support logic will be deleted in the v1.15 release.

All Changes

  • Check resource Group Version and Kind is available in cluster before attempting restore to prevent being stuck (#7336, @kaovilai)
  • Make "disable-informer-cache" option false(enabled) by default to keep it consistent with the help message (#7294, @ywk253100)
  • Fix issue #6928, remove snapshot deletion timeout for PVB (#7282, @Lyndon-Li)
  • Do not set "targetNamespace" to namespace items (#7274, @reasonerjt)
  • Fix issue #7244. By the end of the upload, check the outstanding incomplete snapshots and delete them by calling ApplyRetentionPolicy (#7245, @Lyndon-Li)
  • Adjust the newline output of resource list in restore describer (#7238, @allenxu404)
  • Remove the redundant newline in backup describe output (#7229, @allenxu404)
  • Fix issue #7189, data mover generic restore - don't assume the first volume as the restore volume (#7201, @Lyndon-Li)
  • Update CSIVolumeSnapshotsCompleted in backup's status and the metric
    during backup finalize stage according to async operations content. (#7184, @blackpiglet)
  • Refactor DownloadRequest Stream function (#7175, @blackpiglet)
  • Add --skip-immediately flag to schedule commands; --schedule-skip-immediately server and install (#7169, @kaovilai)
  • Add node-agent concurrency doc and change the config name from dataPathConcurrency to loadCocurrency (#7161, @Lyndon-Li)
  • Enhance hooks tracker by adding a returned error to record function (#7153, @allenxu404)
  • Track the skipped PV when SnapshotVolumes set as false (#7152, @reasonerjt)
  • Add more linters part 2. (#7151, @blackpiglet)
  • Fix issue #7135, check pod status before checking node-agent pod status (#7150, @Lyndon-Li)
  • Treat namespace as a regular restorable item (#7143, @reasonerjt)
  • Allow sparse option for Kopia & Restic restore (#7141, @qiuming-best)
  • Use VolumeInfo to help restore the PV. (#7138, @blackpiglet)
  • Node agent restart enhancement (#7130, @qiuming-best)
  • Fix issue #6695, add describe for data mover backups (#7125, @Lyndon-Li)
  • Add hooks status to backup/restore CR (#7117, @allenxu404)
  • Include plugin name in the error message by operations (#7115, @reasonerjt)
  • Fix issue #7068, due to a behavior of CSI external snapshotter, manipulations of VS and VSC may not be handled in the same order inside external snapshotter as the API is called. So add a protection finalizer to ensure the order (#7102, @Lyndon-Li)
  • Generate VolumeInfo for backup. (#7100, @blackpiglet)
  • Fix issue #7094, fallback to full backup if previous snapshot is not found (#7096, @Lyndon-Li)
  • Fix issue #7068, due to an behavior of CSI external snapshotter, manipulations of VS and VSC may not be handled in the same order inside external snapshotter as the API is called. ...
Read more