postgresql管理-pg_hba.conf 文件详解管理

pg_hba.conf 文件详解

pg_hba.conf 是 PostgreSQL 中用于控制客户端认证的配置文件,全称为 "Host-Based Authentication"。该文件定义了哪些主机、用户、数据库可以连接 PostgreSQL 服务器,以及使用何种认证方式。

实际解释:

允许主机可以通过什么连接方式和认证方法通过哪个数据库用户连接哪个数据库。

文件位置通常位于:

  • Linux: /etc/postgresql/[version]/main/pg_hba.conf
  • Windows: [PostgreSQL安装目录]/data/pg_hba.conf

文件格式为每行一条记录,每条记录包含以下字段:

  1. 连接类型(local, host, hostssl, hostnossl
  2. 数据库名称
  3. 用户名
  4. 客户端地址(CIDR格式)
  5. 认证方法(trust, reject, md5, scram-sha-256, peer等)

常用认证方法

  • trust: 无需密码直接连接
  • reject: 拒绝连接
  • md5: 使用MD5加密密码
  • scram-sha-256: 更安全的SCRAM-SHA-256加密(PostgreSQL 10+推荐)
  • peer: 使用操作系统用户名认证(仅local连接)
  • cert: SSL客户端证书认证
  • ident: 通过ident服务器认证

常见配置示例

允许本地所有用户无密码访问所有数据库:

复制代码
local   all             all                                     trust

允许192.168.1.0/24网段用户通过密码访问特定数据库:

复制代码
host    mydb           myuser        192.168.1.0/24          scram-sha-256

拒绝来自10.0.0.5的特定用户连接:

复制代码
host    all             baduser       10.0.0.5/32             reject

要求SSL加密连接:

复制代码
hostssl  all             all            0.0.0.0/0               cert

允许本地操作系统用户同名连接(Unix域套接字):

复制代码
local   all             all                                     peer

允许特定IP范围的复制用户连接:

复制代码
host    replication     replicator     192.168.2.0/24          md5

配置注意事项

修改pg_hba.conf后需要重新加载配置生效:

sql 复制代码
SELECT pg_reload_conf();

每条规则按顺序匹配,第一个匹配的规则将被应用。建议将更具体的规则放在前面,通用规则放在后面。

生产环境应避免使用trust认证方式,推荐使用scram-sha-256或证书认证。

IPv6地址需要使用::1/128等格式表示,如:

复制代码
host    all             all            ::1/128                 scram-sha-256
相关推荐
周杰伦的稻香2 小时前
PostgreSQL基础命令
数据库·postgresql
先做个垃圾出来………2 小时前
JSON序列化问题
数据库·json
我科绝伦(Huanhuan Zhou)2 小时前
InnoDB Undo Log 深度解析:从原理到实现(基于 MySQL 8.0)
数据库·mysql
jackiehome3 小时前
SQL数据库无法操作,日志文件损坏修复
数据库·sql·oracle
荒川之神3 小时前
ORACLE导入导出实验
数据库·oracle
执笔为剑3 小时前
利用逻辑备份修复误操作的库
数据库·kingbase
程序员夏末3 小时前
【MySQL | 第三篇】 MySQL索引详解
数据库·mysql
leoZ2313 小时前
innodb理解
数据库
NaMM CHIN4 小时前
SQL sever数据导入导出实验
数据库·sql·oracle
山峰哥5 小时前
告别“点点点”:AI 如何重构我们的测试体系与质量防线
服务器·汇编·数据库·人工智能·性能优化·重构