【报错记录】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
相关推荐
一 乐2 分钟前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot
微学AI1 小时前
内网穿透的应用-突破局域网束缚,MongoDB 远程访问使用cpolar原来可以这么简单
数据库·mongodb
大锦终3 小时前
【MySQL】内置函数
数据库·mysql
猿小喵3 小时前
索引优化-MySQL性能优化
数据库·mysql·性能优化
n***F8754 小时前
修改表字段属性,SQL总结
java·数据库·sql
q***78375 小时前
mysql表添加索引
数据库·mysql
翔云1234566 小时前
MySQL 机器重启后,gtid_executed 是如何初始化的
数据库·mysql·adb
JAVA学习通6 小时前
Mysql进阶---存储过程&变量&SQL编程
数据库·mysql
阿里云大数据AI技术6 小时前
朝阳永续基于阿里云 Milvus 构建金融智能投研产品“AI 小二”
数据库·人工智能