-
-
Notifications
You must be signed in to change notification settings - Fork 1k
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 read only postgres nodes #2429
Comments
This would mean connecting to different PostgreSQL databases on the same PostgREST instance right? I recall that Wolfgang suggested somewhere that this would be possible with the Host header, so you could choose to what db instance to connect. In theory it seems possible if we support multiple db connection pools(one for each db). |
Yes, same database but with read only copies of the master. The idea would be that PostgRest could redirect the request to one pool or another pool considering its type:
|
Correct me if I'm wrong but wouldn't this be possible with postgres +postgREST running on each node (master-backup-backup...), proxy / loadbalancer in front of the cluster and from there forward the request to correct server by the http action? Forwarding GETs to any node and PUT, PATCH, POST, DELETE to master? |
Yes, it might be better to implement this at server level. Closing this, not really necessary as I can implement this as pintoflager suggests, thanks!. |
@yevon I'll reopen this one as I think it would be great for performance to support this natively. Additionally it could serve as a first step towards doing #2798. I think the following config would do:
I think we can implement this off-core, for this we would need a All our read requests (GET, HEAD) use the READ ONLY access mode (ref), and our writes (POST, PATCH, PUT) use the READ WRITE access mode. This fact can be used by the library to decide where to send the queries. The ideal interface would be just a wrapper for the The access mode is available for us on https://hackage.haskell.org/package/hasql-transaction-1.0.1.2/docs/Hasql-Transaction-Sessions.html#t:Mode |
That would be amazing for proper support for kubernetes postgres operators like cloudnative postgres operator, or the zalando postgres operator. It could be something like:
I think that that would be enough, just considering a single primary writeable node, and multiple read only nodes because as far as I know Postgres does not support multi-master architectures natively. I'm currently migrating from the zalando postgres operator to the cloudnative one, and it also just supports one write primary node, but multiple standby nodes (but you always write to the primary anyway). |
Until this is implemented my solution is to have two instances of PostgREST behind an NGINX routing requests based on HTTP method. The only problem with this is that PostgREST instance connected to a replica won't receive notifications on pgrst channel. So I've created a small tool to handle this: https://github.com/mkleczek/pg-notify-stdout - see readme for motivation and example usage. |
@mkleczek That's a good suggestion, in fact that would solve #2781. Hm, though each postgrest replica instance would need an additional connection to the master to do the LISTEN right? That seems wasteful. Having native support for read replicas would avoid this problem. |
Just to note I've been working on this, struggled a bit to get a test setup up and running but I should have something ready in a day or two. |
Using a psql compatible INI file (#3101 (comment)) would allow us to configure replicas like: [serviceone]
port=5432
user=stevechavez
dbname=stevechavez
[replicaone]
port=5432
host=...
[replicatwo]
port=5432
host=..
[serviceone.postgrest]
jwt-secret = xxxx
db-pool = 10
db-replicas = "replicaone,replicatwo" |
Any updates for this? |
Does PostgREST support read only postgres nodes? The idea behind this would be being able to specify a backend url for GET requests only, and another backend url for any modify request (PUT, POST, PATCH, DELETE).
I could really duplicate the postgRest instance, one for every kind of requets (read only or modify) and change the application to call one or another depending on the request type, but it would be nice that this could be transparent to the application.
The text was updated successfully, but these errors were encountered: