【报错记录】OpenGauss/磐维数据库连接报:org.postgresql.util.PSQLException: 致命错误: 账户被锁定
前言
目前在搞数据库国产化适配的,这次遇到的是SpringBoot项目应该是密码输错了,导致多次连接失败后账号被磐维数据库给锁了,导致SpringBoot项目再也连不上了报错内容为:
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社区
解决方案就是将失败登录次数改大,然后解锁已经被锁定的用户:
进入数据库,并查看当前失败登录尝试次数
# 在安装OpenGauss/磐维数据库的服务器上执行,并切换到omm用户
su omm# 使用gsql登录进数据库
gsql# 查看当前登录失败尝试次数
SHOW failed_login_attempts;
目前来看次数只有5次,难怪这么快账号就被锁定了
退出数据库,设置失败登录尝试次数
# 退出数据库
\q# 设置失败尝试次数为100次gs_guc reload -D /database/panweidb/data -c "failed_login_attempts=100"
注意!!上面的/database/panweidb/data需要改为你自己的数据库安装路径,需要到data这一层目录,其中必须要包含postgresql.conf这个文件
解锁用户
重新进入数据库,执行:
# 重新进入数据库
gsql# 解锁用户
ALTER USER ${改为你的用户名} ACCOUNT UNLOCK;# 加锁用户
ALTER USER ${改为你的用户名} ACCOUNT LOCK;# 再次解锁用户
ALTER USER ${改为你的用户名} ACCOUNT UNLOCK;
第一次解锁不成功,可以尝试手动加锁后再次解锁试试,我反正按照这一套操作下来用户就被完全解锁了,SpringBoot项目也能重新连接成功了。