Details
Description
I have attempted to install Oozie with Postgres db backend via HDP 2.4. I was able to test DB connection via Ambari, everything was correct. However, the server failed to start with this error:
2016-07-15 11:46:39,580 INFO URIHandlerService:520 - SERVER[hadoop-master01.production.sociablelabs.net] Loaded default urihandler org.apache.oozie.dependency.FSURIHandler 2016-07-15 11:46:40,323 INFO HadoopAccessorService:520 - SERVER[hadoop-master01.production.sociablelabs.net] password key is oozie.service.JPAService.jdbc.password 2016-07-15 11:46:40,331 INFO HadoopAccessorService:520 - SERVER[hadoop-master01.production.sociablelabs.net] credential provider path is null 2016-07-15 11:46:40,337 INFO HadoopAccessorService:520 - SERVER[hadoop-master01.production.sociablelabs.net] password is null 2016-07-15 11:46:41,176 FATAL Services:514 - SERVER[hadoop-master01.production.sociablelabs.net] Runtime Exception during Services Load. Check your list of 'oozie.services' or 'o ozie.services.ext' 2016-07-15 11:46:41,194 FATAL Services:514 - SERVER[hadoop-master01.production.sociablelabs.net] E0103: Could not load service classes, Cannot create PoolableConnectionFactory (F ATAL: password authentication failed for user "oozie") org.apache.oozie.service.ServiceException: E0103: Could not load service classes, Cannot create PoolableConnectionFactory (FATAL: password authentication failed for user "oozie") at org.apache.oozie.service.Services.loadServices(Services.java:309) at org.apache.oozie.service.Services.init(Services.java:213) .... Caused by: org.postgresql.util.PSQLException: FATAL: password authentication failed for user "oozie" at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:291) at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:108) at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:66) ...
Schema verification at startup worked fine and I could not find any bugs related to it. So, I started getting suspicious about my password value, which was like "pO,e43DpjK" (not exactly but it was a bunch of letters, number and one comma). I suspected that the comma was probably interpreted as a value list separator so I have changed the password removing the comma. Server started flawlessly.
I am not 100% sure if it is Ambari that should be escaping (or validating?) the value or Oozie that fails to read the value as single string.
Attachments
Attachments
Issue Links
- fixes
-
OOZIE-2414 Oozie fails to start when db password contains { or }
- Resolved
We encountered the same issue when installing Oozie as part of Cloudera's CDH. Our password contained the special characters "!" and "*". The scripts creating the Oozie DB ran fine (using Postgres), but Oozie itself wouldn't start, printing a similar authentication error. Removing the special characters solved the issue.
Therefore, this does not seem to be an Ambari issue, but something in core Oozie is mangling the passwords...