【报错记录】OpenGauss/磐维数据库连接报:org.postgresql.util.PSQLException: 致命错误: 账户被锁定

前言

目前在搞数据库国产化适配的,这次遇到的是SpringBoot项目应该是密码输错了,导致多次连接失败后账号被磐维数据库给锁了,导致SpringBoot项目再也连不上了报错内容为:

bash 复制代码
2025-09-02 20:37:38.086 [Druid-ConnectionPool-Create-1309638748] ERROR com.alibaba.druid.pool.DruidDataSource - create connection SQLException, url: jdbc:postgresql://172.16.0.154:17700/****, errorCode 9617, state 28000
org.postgresql.util.PSQLException: [172.16.0.153:52028/172.16.0.154:17700] 致命错误: 账户被锁定
        at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:614)
        at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:157)
        at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:233)
        at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:53)
        at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:279)
        at org.postgresql.Driver.makeConnection(Driver.java:568)
        at org.postgresql.Driver.connect(Driver.java:317)
        at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1644)
        at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1710)
        at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2779)

解决方案

由于磐维用的就是OpenGauss,因此只需要找OpenGauss的官方文档即可。

文档地址:设置帐户安全策略 | openGauss文档 | openGauss社区

解决方案就是将失败登录次数改大,然后解锁已经被锁定的用户:

进入数据库,并查看当前失败登录尝试次数

bash 复制代码
# 在安装OpenGauss/磐维数据库的服务器上执行,并切换到omm用户
su omm

# 使用gsql登录进数据库
gsql

# 查看当前登录失败尝试次数
SHOW failed_login_attempts;

目前来看次数只有5次,难怪这么快账号就被锁定了

退出数据库,设置失败登录尝试次数

bash 复制代码
# 退出数据库
\q

# 设置失败尝试次数为100次
 gs_guc reload -D /database/panweidb/data -c "failed_login_attempts=100"

注意!!上面的/database/panweidb/data需要改为你自己的数据库安装路径,需要到data这一层目录,其中必须要包含postgresql.conf这个文件

解锁用户

重新进入数据库,执行:

bash 复制代码
# 重新进入数据库
gsql

# 解锁用户
ALTER USER ${改为你的用户名} ACCOUNT UNLOCK;

# 加锁用户
ALTER USER ${改为你的用户名} ACCOUNT LOCK;

# 再次解锁用户
ALTER USER ${改为你的用户名} ACCOUNT UNLOCK;

第一次解锁不成功,可以尝试手动加锁后再次解锁试试,我反正按照这一套操作下来用户就被完全解锁了,SpringBoot项目也能重新连接成功了。

重启数据库

修改完成后建议重启数据库,不然可能还是不生效,因为我后面又发现好多次用户被锁定的事,还得我自己手动解锁,建议重启数据库

bash 复制代码
gs_om -t stop
gs_om -t start
相关推荐
小志开发1 天前
SQL从入门到起飞:完整学习数据库与100+练习题
数据库·sql·学习·mysql·oracle·sqlserver·navcat
轩情吖1 天前
Qt常用控件之QLabel(一)
开发语言·数据库·c++·qt·小程序·qlabel·桌面开发
汽车仪器仪表相关领域1 天前
工业安全新利器:NHQT-4四合一检测线系统深度解析
网络·数据库·人工智能·安全·汽车·检测站·汽车检测
lypzcgf1 天前
Coze源码分析-资源库-创建数据库-后端源码-安全与错误处理
数据库·安全·go·coze·coze源码分析·ai应用平台·agent平台
望获linux1 天前
【实时Linux实战系列】实时安全 C++ 模式:无异常、预分配与自定义分配器
java·linux·服务器·开发语言·数据库·chrome·tomcat
TDengine (老段)1 天前
TDengine 聚合函数 VAR_POP 用户手册
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
不剪发的Tony老师1 天前
SQLite Expert:一款功能强大的SQLite管理工具
数据库·sqlite
麦当_1 天前
Cloudflare Workers 环境下的数据库死锁问题及解决方案
javascript·数据库·后端
xhbh6661 天前
【硬核对比】Hive与MySQL全方位深度对比:从架构、SQL语法到应用场景,搞懂选型不踩坑
数据库·mysql·hive和mysql的区别
奋进的白羊1 天前
clickhouse使用问题记录
数据库·clickhouse