pgsql配置密码复杂度策略

配置pgsql的密码策略主要用到的是passwordcheck.so,保证passwordcheck.so在/usr/pgsql-15/lib下即可配置,/usr/pgsql-15/lib为例,具体以实际路径为主

1、要配置密码复杂度策略需要安装readline库和zlib库

#安装readline库,zlib库

bash 复制代码
yum install readline-devel zlib-devel

2、查找pgsql的实际相关路径,配置密码策略

#查询pg_config文件位置

bash 复制代码
find / -name pg_config

将查询到的pg_config路径配置环境变量

bash 复制代码
export PATH=$PATH:/usr/pgsql-15/bin

#使环境变量生效

bash 复制代码
source ~/.bashrc

#测试pg_config是否生效,输入pg_config后有信息显示

使用pg_config查看pgsql的相关路径

bash 复制代码
pg_config

找到LIBDIR路径并进入

bash 复制代码
cd /usr/pgsql-15/lib

ls查看有无passwordcheck.so

3、有passwordcheck.so则可以配置密码策略,有两种方式配置(一般yum安装/usr/pgsql-15/lib中都会有此模块)

一是进入到postgresql的控制台配置

#配置shared_preload_libraries

bash 复制代码
postgres=# alter system set shared_preload_libraries='passwordcheck';

配置完成后保存退出,重启数据库并查看pg运行状态

bash 复制代码
systemctl restart postgresql-15
systemctl status postgresql-15

#查看配置是否生效,进入postgresql控制台

bash 复制代码
postgres=# show shared_preload_libraries;
 shared_preload_libraries 
--------------------------
 passwordcheck

若输出passwordcheck则证明配置成功。

二是直接在postgresql.conf中配置密码策略

bash 复制代码
vim /var/lib/pgsql-15/data/postgresql.conf

找到shared_preload_libraries并配置

bash 复制代码
shared_preload_libraries =  'passwordcheck'

配置完成后保存退出,重启数据库并查看pg运行状态

bash 复制代码
systemctl restart postgresql-15
systemctl status postgresql-15

#查看配置是否生效,进入postgresql控制台

bash 复制代码
postgres=# show shared_preload_libraries;
 shared_preload_libraries 
--------------------------
 passwordcheck

若输出passwordcheck则证明配置成功。

4、无passwordcheck.so可能是使用二进制编译安装,需要找到编译过的pgsql二进制包下的/contrib/passwordcheck/目录中寻找,

将其复制到/usr/pgsql/lib中,此路径/usr/pgsql/lib为例,以你服务器pg_config输出的实际路径为准

后续操作与上面两种有passwordcheck.so的配置方式一致

相关推荐
jiayou646 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest3 天前
数据库SQL学习
数据库·sql
jnrjian3 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle