-
-
Notifications
You must be signed in to change notification settings - Fork 3k
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
Badger2 integration #7705
Badger2 integration #7705
Conversation
Thank you for submitting this PR!
Getting other community members to do a review would be great help too on complex PRs (you can ask in the chats/forums). If you are unsure about something, just leave us a comment.
We currently aim to provide initial feedback/triaging within two business days. Please keep an eye on any labelling actions, as these will indicate priorities and status of your contribution. |
@gammazero your go.mod files are conflicting with master. Could you rebase when you get a chance? |
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.
Looking good. Added a couple small comments and a suggestion on the compression + blockCacheSize parameters.
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.
🚀
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.
This looks good to go pending a release of go-ds-badger2 and upgrading go-ipfs-config to v0.10.0
This is a provisional PR and should not be merged until dependencies are merged into their master branches. - Add badger2 plugin - Update docs to describe badger2 - Add tests for badger2 - Add options to configure compression and blockCacheSize - Document vlogFileSize config param - Update go-ipfs-config - Update go-ds-badger2
549a3fa
to
914d390
Compare
This is blocked by the badger folks figuring out if there latest breaking changes will be handled within badger v2 or whether there will be a badger v3. The go-ipfs-config PR adding badger 2 support has been reverted until this is resolved. |
@aschmahmann There's now a Badger v3 https://github.com/dgraph-io/badger/releases/tag/v3.2011.1 However, go-ds-badger2 is actively maintained. Requirements mentioned by you have been met a long time ago and, even as an experimental feature, it could gain great benefit and insight to have something less broken to test with. This might also yield useful feedback while a move towards badger 3 is made. We currently have a badgerdb in IPFS which is broken in obvious ways making it unsuitable for production. |
In short; all that's necessary to have a badger v2, based on actively maintained code, in master, is to resolve these merge conflicts. Getting v3 support is probably a fair amount of work and might delay having something working by several months/up to a year. It would be great to have this in user's hands! |
I tried to use V3, but it will panic in some cases. |
@aschmahmann Poke! |
At ipfs-search.com we currently have a script running from a cron job which stops IPFS, flattens the datastore using the badger binary and then restarts IPFS. I know you've got a lot on your hands, but it would be great to see some progress on this one! |
Poke! |
flatfs is not good when you've got 10s to 100s of gigs in IPFS. One of my use cases can survive with a manual flatten as suggested by @dokterbob but it would be nice if we had badger v2 or v3 to work with edit: i may just rebase this on kubo v14.0 and badger v2.2007.4 and see what happens... edit2: also learned that flatten is not the same as garbage collection; flatten is a different thing in Badger where it consolidates storage layers but has nothing to do with freeing up space. But freeing up some space could be a side effect. |
@dokterbob I have a branch with Badger2 working on IPFS v0.14.0 and garbage collection does work properly |
This is a provisional PR and should not be merged until dependencies are merged into their master branches.