我有PSQL运行,并试图得到一个perl应用程序连接到数据库。是否有命令来查找数据库正在运行的当前端口和主机?


当前回答

从终端你可以简单地做一个“postgres列表集群”:

pg_lsclusters

它将返回Postgres版本号、集群名称、端口、状态、所有者以及数据目录和日志文件的位置。

其他回答

PostgreSQL默认端口号为5432。运行数据库的主机应该是由您的主机提供商提供的;如果没有指定,我猜它应该是与web服务器相同的主机。通常这将被配置为localhost,假设您的web服务器和数据库服务器在同一主机上。

SELECT *
FROM pg_settings
WHERE name = 'port';

从终端你可以做:

\conninfo

我建议阅读一份关于他们所有命令的详尽列表的文档:

\?

@ a_horis_with_no_name答案的补充。 获取主机名:

SELECT boot_val,reset_val FROM pg_settings WHERE name='listen_addresses';;

我使用这样的解决方案。不需要插件。不需要临时表。仅适用于unix。

select pg_read_file('/etc/hostname') as hostname, setting as port from pg_settings where name='port';