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
相关推荐
清水白石00820 小时前
从“点一下导出”到生产级任务队列:Python 异步导出系统设计全景解析
java·数据库·python
快乐的哈士奇20 小时前
历史对话关联 RAG 上下文检索 — 内部技术介绍
服务器·数据库·oracle
半夜修仙20 小时前
Redis中List数据类型的常见命令
数据库·redis·缓存
wujt888820 小时前
mysql 比较数据库
数据库·mysql·oracle
tongluowan00720 小时前
怎么保证缓存和数据库的一致性
java·数据库·缓存·一致性
恣艺20 小时前
用Go从零实现一个高性能KV存储引擎:B+Tree索引、WAL持久化、LRU缓存的工程实践
开发语言·数据库·redis·缓存·golang
TDengine (老段)20 小时前
TDengine 支持数据类型深度解析 — 类型体系、存储编码与选型指南
java·大数据·数据库·系统架构·时序数据库·tdengine·涛思数据
weelinking1 天前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934611 天前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋91 天前
windows中安装redis
数据库·redis·缓存