PostgreSQL Remote Access (Linux + macOS)
The Instructions for Setting Remote Access to PostgreSQL Database
Enable Remote Access to PostgresSQL on Linux
System Information
- 
    Ubuntu 22.04.4 LTS + Linux 6.5.0-25-generic 
- 
    PostgreSQL version 14 (following official installation steps) 
Step 1 - Necessary File Modifications
- 
    For the file postgresql.conf:sudo nano /etc/postgresql/14/main/postgresql.confchange the line #listen_addresses = 'localhost'to listen_addresses = '*'which allows PostgreSQL to listen on all available IP addresses 
- 
    For the file pg_hba.conf:sudo nano /etc/postgresql/14/main/pg_hba.confchange the line host all all 127.0.0.1/32 scram-sha-256to host all all 0.0.0.0/0 scram-sha-256which allows remote access to all users and databases from any IP address 
Step 2 - Restart PostgreSQL
sudo service postgresql restart
sudo service postgresql status
Enable Remote Access to PostgresSQL on macOS
System Information
- 
    macOS Sonoma 14.4 (Apple Silicon M2) 
- 
    PostgreSQL version 16 (following tutorial installation steps) 
Step 1 - Necessary File Modifications
- 
    For the file postgresql.conf:the rootuser owns this filesudo nano /Library/PostgreSQL/16/data/postgresql.confchange the line #listen_addresses = 'localhost'to listen_addresses = '*'which allows PostgreSQL to listen on all available IP addresses 
- 
    For the file pg_hba.conf:since the PostgresSQL is installed along with a new system-level user, by default named postgreswhich owns the directory /Library/PostgreSQL/16/dataand the filepg_hba.conf, it is necessary to switch usersudo su postgres whoamithen, modifications can be done acting as postgresnano /Library/PostgreSQL/16/data/pg_hba.confchange the line host all all 127.0.0.1/32 scram-sha-256to host all all 0.0.0.0/0 scram-sha-256which allows remote access to all users and databases from any IP address 
Step 2 - Restart PostgreSQL
/Library/PostgreSQL/16/bin/pg_ctl stop -D /Library/PostgreSQL/16/data/
/Library/PostgreSQL/16/bin/pg_ctl start -D /Library/PostgreSQL/16/data/
Remote Access PostgreSQL Databases via pgAdmin 4
Step 1 - Installation
Follow the offical installation steps for Linux and macOS
Step 2 - Connection
Follow the official installation steps in help documentation
