Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(backup): support recurring and ondemand full backup #2709

Merged
merged 1 commit into from
Jun 28, 2024

Conversation

ChanYiLin
Copy link
Contributor

@ChanYiLin ChanYiLin commented Mar 21, 2024

ref: longhorn/longhorn#7070

backupstore: If the backup has the parameter backupmodea: full, it will pretend there is no last backup, and backup all the blocks of the current volume.

longhorn-manager:

RecurringJob app

  • Add a new field .Spec.Parameters
  • Get recurringJob.Status.ExecutionCount, +1 , then update it backup to the status
  • if the parameter["full-backup-interval"] = N
    • "0": always incremental
    • "1": always full
    • "N": every N
  • Create the Backup through API and pass the parameter to the Backup if job.executionCount%interval == 0
    • parameters: {"backup-mode": "full"}

Backup

  • Add a new field .Spec.Parameters
  • Add .Status.NewlyUploadedDataSize and .Status.ReUploadedDataSize to each Backup. So user can know the data transfer size for each Backup to trace the cost.
  • pass the parameter to the snapshotBackup (improxy -> replica) to do the full backup

Webhook

  • For Backup, validate the Backup.Spec.Parameters: only support "backup-mode: full/incremental"
  • For RecurringJob, validate the RecurringJob.Spec.Parameters: only support "full-backup-interval: N"

CRD

  • Add .Spec.Parameters to Backup
  • Add .Spec.Parameters to RecurringJob
  • Add .Status.BackupCount to BackupVolume.
  • Add .Status.NewlyUploadedDataSize and .Status.ReUploadedDataSize to Backup

API

  • Add Parameters to the SnapshotInput{}
  • Add BackupCount to BackupVolume{}

@ChanYiLin ChanYiLin self-assigned this Mar 21, 2024
@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 7 times, most recently from 97fecb4 to e9de905 Compare March 26, 2024 06:18
@ChanYiLin ChanYiLin changed the title feat(backup): add option validation for backup creation feat(backup): support recurring and ondemand full backup Mar 26, 2024
@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 2 times, most recently from 4d99c6c to 64b4d30 Compare March 29, 2024 09:35
Copy link

mergify bot commented Mar 29, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 5 times, most recently from 9c979dc to a480c0d Compare April 2, 2024 08:00
@ChanYiLin
Copy link
Contributor Author

ChanYiLin commented Apr 2, 2024

Copy link

mergify bot commented Apr 18, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

1 similar comment
Copy link

mergify bot commented Apr 24, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

@ChanYiLin
Copy link
Contributor Author

Since the grpc proto has been moved to types
I don't want to modify the PR and solve the conflicts
Will close this one and recreate the PR again
cc @derekbit @innobead

@ChanYiLin ChanYiLin closed this May 31, 2024
@ChanYiLin ChanYiLin reopened this May 31, 2024
Copy link

mergify bot commented May 31, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 2 times, most recently from ba772b7 to 0307a44 Compare May 31, 2024 10:28
Copy link

mergify bot commented Jun 1, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 3 times, most recently from 1510810 to bcd7246 Compare June 3, 2024 09:56
Copy link

mergify bot commented Jun 6, 2024

This pull request is now in conflict. Could you fix it @ChanYiLin? 🙏

Copy link
Member

@derekbit derekbit left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In general, LGTM.

k8s/pkg/apis/longhorn/v1beta2/backup.go Outdated Show resolved Hide resolved
k8s/pkg/apis/longhorn/v1beta2/backup.go Outdated Show resolved Hide resolved
k8s/generate_code.sh Outdated Show resolved Hide resolved
engineapi/types.go Show resolved Hide resolved
engineapi/backup_monitor.go Outdated Show resolved Hide resolved
api/snapshot.go Outdated Show resolved Hide resolved
app/recurring_job.go Outdated Show resolved Hide resolved
app/recurring_job.go Show resolved Hide resolved
@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch 3 times, most recently from 8ed2fb4 to 3e96ecb Compare June 26, 2024 04:35
@ChanYiLin ChanYiLin marked this pull request as ready for review June 26, 2024 04:37
@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch from 3e96ecb to bd8339c Compare June 26, 2024 04:58
derekbit
derekbit previously approved these changes Jun 26, 2024
Copy link
Member

@derekbit derekbit left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@ChanYiLin ChanYiLin force-pushed the LH7070_support_full_backup branch from bd8339c to 913999d Compare June 26, 2024 06:34
@ChanYiLin ChanYiLin requested a review from derekbit June 26, 2024 06:38
@derekbit derekbit force-pushed the LH7070_support_full_backup branch from 913999d to 7247efd Compare June 26, 2024 06:59
derekbit
derekbit previously approved these changes Jun 26, 2024
k8s/crds.yaml Outdated Show resolved Hide resolved
ref: longhorn/longhorn 7070

Signed-off-by: Jack Lin <jack.lin@suse.com>
@derekbit derekbit force-pushed the LH7070_support_full_backup branch from 2f02196 to 146db22 Compare June 26, 2024 11:07
@derekbit derekbit merged commit 1c19bfb into longhorn:master Jun 28, 2024
6 of 7 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants