【报错记录】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
相关推荐
2301_8092047012 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全12 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap
阿坤带你走近大数据13 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
yoyo_zzm13 小时前
Laravel8.x新特性全解析
数据库·nginx
码界奇点14 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
我科绝伦(Huanhuan Zhou)14 小时前
探索技术世界:我的GitHub数据库工具宝库
数据库·github
猫的玖月15 小时前
(一)MY SQL概述
数据库·sql
脑子进水养啥鱼?15 小时前
PostgreSQL .history 文件
数据库·postgresql
倔强的石头_16 小时前
5 个真实案例带你避坑:DolphinDB 实时写入、流订阅与高可用调优
数据库
虹科网络安全16 小时前
艾体宝新闻|Redis 月度更新速览:2026 年 3 月
数据库·redis·缓存