【报错记录】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
相关推荐
keep__go2 小时前
postgresql9.2.4 跨版本升级14.6
linux·运维·数据库·postgresql
Doris_LMS2 小时前
Git的强软硬回退(三)
运维·服务器·数据库·git·idea
williamdsy3 小时前
【postgresql】JPA LIKE 查询触发 PostgreSQL `text ~~ bytea` 报错的排查与最佳实践
数据库·postgresql
川石课堂软件测试3 小时前
Oracle 数据库如何查询列
linux·数据库·sql·功能测试·oracle·grafana·prometheus
2501_927030785 小时前
NOSQL——Redis
数据库·nosql
光电的一只菜鸡5 小时前
ubuntu之坑(十九)——VMware虚拟机扩容磁盘
linux·数据库·ubuntu
C语言小火车6 小时前
【C++八股文】数据结构篇
数据结构·数据库·c++·c++八股文
CHEN5_026 小时前
【CouponHub项目开发】EasyExcel解析Excel并使用线程池异步执行和延时队列兜底
java·数据库·excel
川石课堂软件测试7 小时前
Oracle 数据库使用事务确保数据的安全
数据库·python·功能测试·docker·oracle·单元测试·prometheus