PostgreSQL远程访问数据库 配置

默认情况下,PostgreSQL不允许全面的远程访问。为了赋权给远程连接,你必须编辑配置文件pg_hba.conf。这个文件存在于数据库文件的区域,它包含允许或者拒绝特定用户连接到数据库的权限的配置记录。默认情况下,本地用户可以连接但远程用户不允许。

PostgreSQL自带的默认文件包含大量的有用的注释用于协助添加记录。你可以根据需要给单个的用户、主机、计算机组或者单独的数据库赋权。

例如,希望允许用户neil通过IP地址为192.168.0.3的主机连接到bpsimple数据库,添加以下行到pg_hba.conf文件:

host bpsimple neil 192.168.0.3/32 md5

注意,在早于8.0版本的PostgreSQL中,pg_hba.conf通过IP地址和子网掩码说明一个主机地址,所以之前的例子应该写成这样:

host bpsimple neil 192.168.0.3 255.255.255.255 md5

本例中,我们将添加一条记录来运行局域网中(本例中,子网为192.168.x.x)的任何计算机通过密码认证访问数据库。(如果你需要不同的访问策略,参考配置文件里头的注释)我们添加一行到pg_hba.conf的末尾,就像这样:

host all all 192.168.0.0/16 md5

这意味着IP地址由192.168开头的计算机可以访问所有的数据库。此外,加入我们信任网络中的所有用户,我们可以通过指定使用trust标记不受限的访问方法作为访问策略,就像这样:

host all all 192.168.0.0/16 trust

PostgreSQLpostmaster服务进程读取配置文件postgresql.conf(也存在于数据目录中)来设置一系列的运行选项,包括(如果没有另外指定-D选项或者配置PGDATA环境变量)数据库数据文件的位置。这个配置文件被很好的注释了,如果你想修改任何设置,它都提供了向导。PostgreSQL的文档有一章讲述了运行配置。

例如,我们可以设置postgresql.conf文件中的listen_addresses参数允许服务器监听网络连接,而不是通过-i选项:

listen_addresses='*'

实际上,我们推荐通过postgresql.conf设置配置参数来控制postmaster进程的行为。

为了实现 PostgreSQL 数据库远程访问,需要进行以下配置: ### 修改 `postgresql.conf` 在 `postgresql.conf` 文件中进行配置以允许远程连接。此文件通常位于 `/etc/postgresql/<版本号>/main/` 目录下(例如 `/etc/postgresql/13/main/` 或 `/etc/postgresql/9.x/main/`)。编辑或添加以下行以允许接受任意 IP 的连接请求: ```conf listen_addresses = '*' ``` ### 修改 `pg_hba.conf` 接下来,编辑 `pg_hba.conf` 文件,该文件与 `postgresql.conf` 位于同一目录。此文件用于控制客户端认证。添加或修改以下行以允许远程客户端连接: ```conf # 允许任意IP地址连接到所有数据库,使用任意用户和密码认证 host all all 0.0.0.0/0 md5 ``` 这行配置表示允许任何 IP 地址访问所有数据库,并且使用 MD5 密码验证。 ### 配置防火墙 PostgreSQL 默认使用端口 `5432` 进行通信。需要在防火墙中开放此端口以允许远程访问。 #### Linux 系统 在 Linux 系统上,使用 `firewall-cmd` 命令添加并重新加载规则: ```bash firewall-cmd --add-port=5432/tcp --permanent firewall-cmd --reload ``` #### Windows 系统 在 Windows 系统上,按以下步骤操作: 1. 打开 **控制面板** -> **系统与安全** -> **Windows 防火墙**。 2. 点击左侧的 **高级设置**。 3. 在左侧树上选择 **入站规则**,然后在右侧操作栏点击 **新建规则**。 4. 在向导中选择 **端口**,然后点击 **下一步**。 5. 在“特定本地端口”输入框中输入 `5432`,然后继续点击 **下一步** 直到完成。 6. 为规则命名,例如“postgresql rule”。 ### 重启 PostgreSQL 服务 完成上述配置后,需要重启 PostgreSQL 服务以使更改生效。在 Linux 系统上,可以使用以下命令重启服务: ```bash sudo systemctl restart postgresql ``` ### 测试远程连接 使用远程客户端工具(例如 `psql` 或图形化工具如 PgAdmin)测试连接。确保客户端连接命令或工具中指定正确的主机名(或 IP 地址)、端口、数据库名称、用户名和密码。 例如,使用 `psql` 测试连接: ```bash psql -h <远程服务器IP> -p 5432 -U <用户名> -d <数据库名> ``` 如果一切配置正确,应能成功连接PostgreSQL 数据库。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值