-
Notifications
You must be signed in to change notification settings - Fork 1
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
Db scale out of SQLite using NATS #16
Comments
That looks cool. I'm not sure if xtemplate needs to do anything in particular to enable this, it should work out of the box given that marmot is a sidecar process. |
true. Maybe add it to the README or some pertinent area of the docs. SQLITE and scalout / backup is a common need. |
I have since moved to use the SQL Server that another golang htmx system uses. I still use xtemplate, but I had to marry it with other things to get the DB and other things working with it. https://github.com/delaneyj/toolbelt/tree/main/sqlc-gen-zombiezen Which is used by the datastar project which is a type of htmx rendering system. Its has SSE built in, and so the DB changes can feed the HTMX. It uses NATS Jetstream so marry up SQL changes to be a stream that feeds the HTMX layer. So now it's all reactive. Change the data and everything above it changes. SO NATS and the DB are married up, allowing DB scale out also. NATS can run InProcess now too, so you can do it without any sockets IF you want. Marmot does it the other way around, and sits behind the DB listening to the WAL. This means that the transaction has already been make on one of the DB's. It's good, and faster but less safe and also cant do real time migrations, because the schema has already changed on 1 of the instances. When the data flows through NATS, it's much easier. It does not have to be slow, because you can run as many NATS Servers as you want in your architecture, with each doing different things at different layers of your architecture. |
Can you say a bit more about which projects you're integrating with xtemplate? I'm curious about your design here. |
Open science it’s an EU project to allow scientists to collaborate. Like Google workspace but self hosted on premise . The data resides on premise , and nats provides a tunnel . |
That sounds like a cool project. I'm also curious about what other Go libraries you are integrating with xtemplate to build it. Specifically, you mentioned:
What is the other golang htmx system, and what are the other things you had to marry to get the db and other things working? |
Well the project is in a state of flux. The main thing is that it's fully reactive so just use a SQLITE DB for now with NATS tracking what SQL query a HTTP Endpoint is mapped to. It's like a presence system, so we know when to do a HTMX push over SSE when the DB changes. Does that makes sense ? When the user moves to a different http or http fragment, we just have to track that. Nats has so many uses !! |
I will open other issues about other aspects I am working on with Xtemplate . For now it was about sql scale out , so that the db is HA . marmot runs as a separate process , but I need to test it with the current SQLite provider . Can then submit a proper PR . It will probably just need a task or make file to set it up , run it and massage the caddy config perhaps . |
Have you looked into something like litestream? https://litestream.io/ |
Yeah I know LiteStream. It works but has 2 things I dont like
Marmot is also behind the DB, and can replicate to S3 or many other Sqlite DB's and is Mukti master. The only change to do with Marmot is to also have NATS in front as an agent and to detect a SQL Migration, by having it pass through NATS, before it hits the DB. Then you can stop the world, make sure they are all caught up, replicate the SQL migration to all instances, and then start the world again. The SQL migration also goes into the snapshot. you must have this because if you need to go back in time to a snapshot you need the schema at that time. This is why the Fly team ( who also employ the Litestream person) are building corrosion. The corrosion CDC stream can be parsed using golang, so we can use it too. Have a look at : https://github.com/superfly/corrosion/tree/main/examples/fly it even has a tempting lang. Like Marmot is designed for Multi Master. so lots of other options then LiteStream that have different properties than LiteStream. CDC of the SQL Schema is the key one. |
I would like to suggest https://github.com/maxpert/marmot be considered as a SQLite db scale out approach.
It uses NATS and so it’s a nice synergy for the nats kv provider.
Marmot is currently used for SQLite Db.
It provides a multi master strategy at the moment, using a LWW ( last write wins ) strategy. There are some trade offs with this like any multi master scenario.
This will mean that all instances of caddy can have a db, so any downtime of any instance will not affect the global system. When it comes back up it will catchup.
New instances will also catchup I believe.
DB Schema migrations are not yet part of marmot. There is an issue for it.
it’s currently used with pocketbaae too. I have run it and it worked well.
please let me know how you feel about this @infogulch
The text was updated successfully, but these errors were encountered: