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


当前回答

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

pg_lsclusters

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

其他回答

SELECT *
FROM pg_settings
WHERE name = 'port';

选择inet_server_port ();提供服务器的端口。

要找到端口号,可以运行这个命令(假设您在localhost上)

select setting from pg_settings where name='port';

我认为PostgreSQL没有提供一个内置的函数来获取服务器的主机名,所以我们可能需要写一个扩展来从服务器获取信息。

我发现有一个PostgreSQL扩展pg-hostname,可以从服务器获取主机名。

当我们安装了扩展,我们可以启用,并通过inet_server_port和主机名函数查询信息。

CREATE EXTENSION hostname;

SELECT hostname(),inet_server_port();

右键单击SQL server。我的是PostgresSQL 13和选择属性->连接。这有:

主机名 端口ID 用户名。