我有PSQL运行,并试图得到一个perl应用程序连接到数据库。是否有命令来查找数据库正在运行的当前端口和主机?
当前回答
到“终端机”输入
service postgres status
在结果中,您可以获得端口的详细信息
在我的例子中,它运行在端口“5432”(默认)上。我用的是CentOS 7。希望这能有所帮助。
其他回答
选择inet_server_port ();提供服务器的端口。
要找到端口号,可以运行这个命令(假设您在localhost上)
select setting from pg_settings where name='port';
这是非sql方法。指令是在图像本身上给出的。选择要查找有关信息的服务器,然后按照步骤操作。
这个命令将提供postgres端口号
\conninfo
如果Postgres运行在Linux服务器上,也可以使用下面的命令
sudo netstat -plunt |grep postgres
或者(如果是邮政局长送来的)
sudo netstat -plunt |grep postmaster
你会看到类似的东西
tcp 0 0 127.0.0.1:5432 0.0.0.0:* LISTEN 140/postgres
tcp6 0 0 ::1:5432 :::* LISTEN 140/postgres
在本例中,端口号为5432,也是默认端口号
信贷:链接
我认为PostgreSQL没有提供一个内置的函数来获取服务器的主机名,所以我们可能需要写一个扩展来从服务器获取信息。
我发现有一个PostgreSQL扩展pg-hostname,可以从服务器获取主机名。
当我们安装了扩展,我们可以启用,并通过inet_server_port和主机名函数查询信息。
CREATE EXTENSION hostname;
SELECT hostname(),inet_server_port();
推荐文章
- PostgreSQL错误:由于与恢复冲突而取消语句
- 按IN值列表排序
- 如何在Postgres 9.4中对JSONB类型的列执行更新操作
- PostgreSQL列名区分大小写吗?
- postgresql COUNT(DISTINCT…)非常慢
- Postgres:检查数组字段是否包含值?
- 如何在postgresql中创建数据库用户?
- 使用PSQL命令查找主机名和端口
- Postgresql列表和排序表的大小
- 选择其他表中没有的行
- 在PostgreSQL中使用UTC当前时间作为默认值
- 优化PostgreSQL进行快速测试
- django test app error -在创建测试数据库时出现错误:创建数据库的权限被拒绝
- Postgres唯一约束与索引
- 使用电子邮件地址为主键?