Can I access a postgres database of an app from outside?
-
wrote on Feb 7, 2023, 7:57 PM last edited by girish Feb 9, 2023, 5:04 PM
Curious to know if this is possible? I am using a directus instance which is using a postgres database. Would be awesome to change and look in the postgres directly from a client or a terminal.
-
Curious to know if this is possible? I am using a directus instance which is using a postgres database. Would be awesome to change and look in the postgres directly from a client or a terminal.
@devtron terminal, yes, via the terminal app on an application. External to the app, not at present.
-
@devtron terminal, yes, via the terminal app on an application. External to the app, not at present.
wrote on Feb 7, 2023, 8:37 PM last edited by@doodlemania2 That's a shame, do you or anyone know when it will be possible or if it ever will be?
-
@doodlemania2 That's a shame, do you or anyone know when it will be possible or if it ever will be?
@devtron up to the developers of course. It's technically possible to do it with a number of really complex workarounds involving port forwarding, but just hasn't been much of a demand for it I suspect.
-
Curious to know if this is possible? I am using a directus instance which is using a postgres database. Would be awesome to change and look in the postgres directly from a client or a terminal.
@devtron Depends on the app / client. For example, with mysql workbench , this is quite straight forward because it supports SSH tunneling . Please see https://forum.cloudron.io/topic/3237/remote-sql-support-on-a-per-app-basis/2 . Which client will you be using for postgresql ?
-
Staffwrote on Feb 8, 2023, 8:52 AM last edited by girish Feb 8, 2023, 8:53 AM
pgadmin seems to support this - https://fedingo.com/pgadmin-connect-via-ssh-tunnel/
In general, the good tools should support SSH tunnels, since databases are almost never straight up exposed to the internet. They are in a VPC/Private network and you SSH/VPN into a bastion host.
-
pgadmin seems to support this - https://fedingo.com/pgadmin-connect-via-ssh-tunnel/
In general, the good tools should support SSH tunnels, since databases are almost never straight up exposed to the internet. They are in a VPC/Private network and you SSH/VPN into a bastion host.
-
@devtron neither. I thought you wanted to access the database that directus uses from outside? If so, what tool are you going to use from the outside to connect? That tool should support ssh tunneling.
-
@devtron neither. I thought you wanted to access the database that directus uses from outside? If so, what tool are you going to use from the outside to connect? That tool should support ssh tunneling.
-
@girish Ahh You mean the client (tool), where I connect to the database. I want to use TablePlus and I am sure it has ssh tunneling.
wrote on Feb 9, 2023, 8:08 AM last edited by shrey Feb 9, 2023, 8:09 AMHey @devtron .
I was curious about it too, so just tried the same using DBeaver.
I was able to successfully access Directus' Postgres database by:
- configuring SSH connection to the server that Cloudron is hosted on
- using:
- host = value gotten from the host server by using `docker inspect postgresql | grep IPAddress
- database = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_DATABASE)
- username = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_USERNAME)
- password = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_PASSWORD)
-
Hey @devtron .
I was curious about it too, so just tried the same using DBeaver.
I was able to successfully access Directus' Postgres database by:
- configuring SSH connection to the server that Cloudron is hosted on
- using:
- host = value gotten from the host server by using `docker inspect postgresql | grep IPAddress
- database = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_DATABASE)
- username = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_USERNAME)
- password = value gotten from Directus' 'terminal' (echo $CLOUDRON_POSTGRESQL_PASSWORD)
@shrey Thanks, that motivated me to get started with a guide.
I wrote the mysql guide first - https://docs.cloudron.io/guides/connect-mysql/ . Working on the postgres one (but it's really very similar).
-
PostgreSQL guide is up as well - https://docs.cloudron.io/guides/connect-postgresql/
-
-
-
wrote on Feb 9, 2023, 9:27 PM last edited by
In my case, it also works with table plus
-
wrote on Feb 17, 2023, 7:38 AM last edited by
Hi @girish .
I do have some feedback regarding the currently suggested method, as described in these new guides.
After using this method for quite a few days, finding the internal ip address of the db containers has almost become the Achilles heel for any operation that uses this feature. That's because, the internal ip address keeps on changing, every now and then.
And so far, i haven't been able to identify a way to connect to the db by a static name/ip/uri.
Would appreciate if a solution for that is posted as well!
Thanks.
-
Hi @girish .
I do have some feedback regarding the currently suggested method, as described in these new guides.
After using this method for quite a few days, finding the internal ip address of the db containers has almost become the Achilles heel for any operation that uses this feature. That's because, the internal ip address keeps on changing, every now and then.
And so far, i haven't been able to identify a way to connect to the db by a static name/ip/uri.
Would appreciate if a solution for that is posted as well!
Thanks.
@shrey that's a good point. I think docker can give those containers a different IP on each restart. For the app containers, we solved this by giving them static IPs. Maybe we should do the same for addons then.
-
@shrey that's a good point. I think docker can give those containers a different IP on each restart. For the app containers, we solved this by giving them static IPs. Maybe we should do the same for addons then.
-
@girish ideally an internal DNS mapping if dynamic, and an IP pattern to use if static, both of which should be viewable from the UI as needed.
@robi it already has internal names which is how apps access them with the current dynamic IP situation.
-
I have given these stable IPs now - https://git.cloudron.io/cloudron/box/-/commit/582994b9d646989b42e27dde1ae0c27bbb964834