PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

dblink non utilizza il file .pgpass

Allora, db_link() verrà eseguito sul processo del server di back-end come utente postgres.

Il tuo .pgpass è? file nella posizione corretta per l'utente postgres sul computer del database?

In caso negativo, come ti aspetti che venga letto?

Penso che ti sia sfuggito qualcosa:

# ls -l /var/lib/postgresql/.pgpass 
-rw------- 1 root root 79 Jun 24 08:10 /var/lib/postgresql/.pgpass

(meanwhile, in psql...)
dblinklocal=# SELECT dblink_connect('conn1', 'hostaddr=127.0.0.1 port=5432 dbname=dblinkremote user=testuser');
ERROR:  could not establish connection
DETAIL:  fe_sendauth: no password supplied

# chown postgres:postgres .pgpass
dblinklocal=# SELECT dblink_connect('conn1', 'hostaddr=127.0.0.1 port=5432 dbname=dblinkremote user=testuser');
 dblink_connect 
----------------
 OK
(1 row)