-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
Export backup loader interface and rename Load method. #901
Conversation
The logic in the load method will be moved to Dgraph so that it can support converting keys and values from a different format. To compensate, the loader interface has been exported as KVLoader.
Also add a not telling users to use the KVLoader if more complex logic is needed to restore a backup.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Don't change the APIs in Badger. Rest is good.
Reviewable status: 0 of 3 files reviewed, 1 unresolved discussion (waiting on @manishrjain and @martinmr)
backup.go, line 199 at r1 (raw file):
// DB.DefaultLoad() should be called on a database that is not running any other // concurrent transactions while it is running. func (db *DB) DefaultLoad(r io.Reader, maxPendingWrites int) error {
Keep the name same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: 0 of 1 files reviewed, 1 unresolved discussion (waiting on @manishrjain)
backup.go, line 199 at r1 (raw file):
Previously, manishrjain (Manish R Jain) wrote…
Keep the name same.
Done.
The logic in the load method will be copied to Dgraph so that it can support converting keys and values from a different format. To allow this, the loader interface has been exported as KVLoader. Also add a note telling users to use the KVLoader if more complex logic is needed to restore a backup. (cherry picked from commit 50ccc86)
The loader type has been exported as KVLoader. This will allow Dgraph to implement
custom restore logic (i.e change the format of the keys and values before writing the data).
Originally I deleted the Load method but it's still required by the "badger restore" command.
To indicate that this method just performs a very basic restore, I renamed the method to
DefaultLoad and indicated that more complex restore logic should be implemented using
the KVLoader instead.
This change isdata:image/s3,"s3://crabby-images/d0bb7/d0bb7f7625ca5bf5c3cf7a2b7a514cf841ab8395" alt="Reviewable"