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

support for storing in sqlite3 database #238

Open
2 tasks done
khimaros opened this issue Apr 19, 2024 · 3 comments
Open
2 tasks done

support for storing in sqlite3 database #238

khimaros opened this issue Apr 19, 2024 · 3 comments
Labels
enhancement New feature or request

Comments

@khimaros
Copy link

  • I have checked the existing issues to avoid duplicates
  • I have redacted any info hashes and content metadata from any logs or screenshots attached to this issue

Is your feature request related to a problem? Please describe

deploying an maintaining a PG server is troublesome overhead

Describe the solution you'd like

add support for utilizing an sqlite3 database

@khimaros khimaros added the enhancement New feature or request label Apr 19, 2024
@mgdigital
Copy link
Collaborator

mgdigital commented Apr 23, 2024

I just don't think the performance would be good enough for large indexes, though I appreciate it would be convenient in theory. Most apps using a sqlite DB are not dealing with millions of rows. Bitmagnet makes use of many Postgres features not available in sqlite (most significantly tsvectors for search), so it would be difficult or impossible to achieve feature parity, and the maintenance overhead of 2 database backends would be very big.

I'm leaving open for discussion (for now) but it's unlikely to happen. I am considering integrating something like https://github.com/fergusstrange/embedded-postgres that would set up the Postgres DB automatically.

@jxs
Copy link

jxs commented May 1, 2024

Hi, and thanks for considering this. If I understand correctly your solution using embedded-postgres also achieves the same purpose as sqlite in that we can release a bitmagnet container not dependable on a separate postgres container right?
If so it works for me, I can even try to submit a PR addressing this (if you have patience to guide me as my golang skills are non existent)

@mgdigital
Copy link
Collaborator

Hi, and thanks for considering this. If I understand correctly your solution using embedded-postgres also achieves the same purpose as sqlite in that we can release a bitmagnet container not dependable on a separate postgres container right?

Hi, that's correct although I haven't tried embedded-postgres so not sure what other issues it might throw up. If you're using a container with docker-compose you're probably best sticking with a separate postgres container, I can't really see much of an advantage of embedded postgres in this case. I see this primarily facilitating native install packages for Mac/Windows/linux flatpak etc without separate dependencies, and I expect a separate postgres would remain the default configuration otherwise.

If so it works for me, I can even try to submit a PR addressing this (if you have patience to guide me as my golang skills are non existent)

Thanks, I'd say it's a non-trivial feature to implement- if you'd still like to give it a go I'll assist where I can.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants