You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

WildFly应用连接PostgreSQL密码认证失败求助

PostgreSQL密码认证失败排查(WildFly部署场景)

我在WildFly上部署应用时,遇到了PostgreSQL的密码认证错误:org.postgresql.util.PSQLException: FATAL: password authentication failed for user "myuser"。这个用户是新建的,DriverManager里配置的密码绝对正确,我能通过终端正常登录数据库。我已经尝试修改pg_hba.conf,测试了md5/peer/trust三种认证方式,但都没用,请问怎么让连接正常通过认证?


附相关配置与信息

pg_hba.conf配置

# Database administrative login by Unix domain socket
local all postgres trust
local all myuser trust
# TYPE DATABASE USER ADDRESS METHOD
# "local" is for Unix domain socket connections only
local all postgres trust
local all myuser trust
# IPv4 local connections:
host all all 127.0.0.1/32 trust
# IPv6 local connections:
host all all ::1/128 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local replication postgres trust
#host replication postgres 127.0.0.1/32 trust
#host replication postgres ::1/128 trust

Java连接代码

Connection connection;
Properties props = new Properties();
String url = "jdbc:postgresql://localhost:5432/my_db";
props.setProperty("user","myuser");
props.setProperty("password","password");
try {
    Class.forName("org.postgresql.Driver");
    connection = DriverManager.getConnection(url, props);
}

完整错误栈

13:28:51,267 SEVERE [org.postgresql.Driver] (default task-3) Connection error: : org.postgresql.util.PSQLException: FATAL: password authentication failed for user "myuser"
at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:438)
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:222)
at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:49)
at org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:194)
at org.postgresql.Driver.makeConnection(Driver.java:450)
at org.postgresql.Driver.connect(Driver.java:252)
at java.sql.DriverManager.getConnection(DriverManager.java:664)
at java.sql.DriverManager.getConnection(DriverManager.java:208)
at servlets.EmployeeServlet.getEmployees(EmployeeServlet.java:61)
at servlets.EmployeeServlet.doGet(EmployeeServlet.java:39)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85)
at io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:62)
at io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)
at org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131)
at io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:57)
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:46)
at io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:64)
at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:60)
at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:77)
at io.undertow.security.handlers.NotificationReceiverHandler.handleRequest(NotificationReceiverHandler.java:50)
at io.undertow.security.handlers.AbstractSecurityContextAssociationHandler.handleRequest(AbstractSecurityContextAssociationHandler.java:43)
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
at org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61)
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
at io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:292)
at io.undertow.servlet.handlers.ServletInitialHandler.access$100(ServletInitialHandler.java:81)
at io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:138)
at io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:135)
at io.undertow.servlet.core.ServletRequestContextThreadSetupAction$1.call(ServletRequestContextThreadSetupAction.java:48)
at io.undertow.servlet.core.ContextClassLoaderSetupAction$1.call(ContextClassLoaderSetupAction.java:43)
at io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
at io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
at io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
at io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
at io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
at io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:272)
at io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:81)
at io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:104)
at io.undertow.server.Connectors.executeRootHandler(Connectors.java:202)
at io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:805)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:748)

myuser权限信息

Role nameAttributesMember ofDescription
adminuserSuperuser, Create role, Create DB{}
myuserSuperuser, Create role, Create DB{}
postgresSuperuser, Create role, Create DB, Replication, Bypass RLS{}

解决方案与排查步骤

根据你的情况,终端能正常登录但WildFly里的应用连接失败,大概率是配置未生效或者连接路径的问题,给你几个排查方向:

  • 先确认PostgreSQL重载了配置:修改pg_hba.conf后,必须让PostgreSQL重新加载才能生效。你可以执行pg_ctl reload(如果是服务管理,比如systemctl reload postgresql),或者在psql里运行SELECT pg_reload_conf();。很多人改完配置忘了这一步,导致新规则没起作用。
  • 查看PostgreSQL日志确认匹配的规则:打开PostgreSQL的日志文件(通常在/var/log/postgresql/或者数据目录下),找认证失败的详细记录,里面会显示连接匹配了pg_hba.conf的哪一行规则。比如日志里可能会写FATAL: password authentication failed for user "myuser" DETAIL: Connection matched pg_hba.conf line X: "host all all 127.0.0.1/32 md5",这样就能确认你的trust配置是不是真的被应用了。
  • 重新设置用户密码:虽然终端能登录,但可能存在密码编码问题(比如全角/半角字符、特殊字符的编码差异)。在psql里执行ALTER USER myuser PASSWORD 'password';,和你Java代码里的密码保持完全一致,然后再测试连接。
  • 测试独立Java程序连接:写一个简单的独立Java类,用同样的连接代码直接运行(不要部署到WildFly),如果能成功,说明问题出在WildFly环境里——比如WildFly的类加载冲突、安全策略限制,或者有其他数据源配置干扰;如果也失败,那问题还是在PostgreSQL的配置或者密码本身。
  • 检查JDBC驱动版本兼容性:如果你的PostgreSQL版本较新,但JDBC驱动版本很旧,可能存在兼容性问题。尝试更新到最新的PostgreSQL JDBC驱动(比如42.x系列),替换WildFly中对应的驱动文件。

内容的提问来源于stack exchange,提问作者jimmyrap

火山引擎 最新活动