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
相关推荐
ai_coder_ai6 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql
AOwhisky7 小时前
Redis 学习笔记(第一期):概述、安装配置与核心理论
运维·数据库·redis·笔记·学习·云计算
ytttr8737 小时前
C# 定时数据库备份工具
开发语言·数据库·c#
睡不醒男孩0308237 小时前
自建 Prometheus+Grafana 与 CLUP 深度监控 PG 集群有什么区别?
数据库·oracle
AOwhisky8 小时前
Redis 学习笔记(第四期):高可用与集群(哨兵 + Cluster + 容器化)
linux·运维·数据库·redis·笔记·学习·缓存
猫猫聚会Ing8 小时前
数据库设计 Prompt 提示词 - 构建与迭代
数据库
上海云盾-小余8 小时前
源站隐藏实战:规避裸 IP 被直接攻击的完整方案
数据库·网络协议·tcp/ip
微学AI9 小时前
时序大模型 TimechoAI 赋能工业时序数据底层技术优势与实操
数据库·大模型·时序大模型
北顾笙9809 小时前
MYSQL-day03
数据库·sql·mysql
MXsoft6189 小时前
**混合云统一监控实践:私有云+公有云的一体化运维方案**
运维·网络·数据库