Chaoyu Tang created HIVE-12248:
----------------------------------

             Summary: The rawStore used in DBTokenStore should be thread-safe
                 Key: HIVE-12248
                 URL: https://issues.apache.org/jira/browse/HIVE-12248
             Project: Hive
          Issue Type: Bug
          Components: Authentication
            Reporter: Chaoyu Tang
            Assignee: Chaoyu Tang


A non-thread-safe implementation of RawStore, particularly ObjectStore, set in 
DBTokenStore is being shared by multi-threads, which causes the race condition 
in DataNuclues to access the backend DB. 
The DN PersistenceManager(PM) in ObjectStore is not thread safe, so 
DBTokenStore should use a ThreadLocal ObjectStore.
Following errors might be root caused by the race condition in DN PM.
{code}
Object of type "org.apache.hadoop.hive.metastore.model.MDelegationToken" is 
detached. Detached objects cannot be used with this operation.
org.datanucleus.exceptions.ObjectDetachedException: Object of type 
"org.apache.hadoop.hive.metastore.model.MDelegationToken" is detached. Detached 
objects cannot be used with this operation.
at 
org.datanucleus.ExecutionContextImpl.assertNotDetached(ExecutionContextImpl.java:5728)
at 
org.datanucleus.ExecutionContextImpl.retrieveObject(ExecutionContextImpl.java:1859)
at 
org.datanucleus.ExecutionContextThreadedImpl.retrieveObject(ExecutionContextThreadedImpl.java:203)
at 
org.datanucleus.api.jdo.JDOPersistenceManager.jdoRetrieve(JDOPersistenceManager.java:605)
at 
org.datanucleus.api.jdo.JDOPersistenceManager.retrieveAll(JDOPersistenceManager.java:693)
at 
org.datanucleus.api.jdo.JDOPersistenceManager.retrieveAll(JDOPersistenceManager.java:713)
at 
org.apache.hadoop.hive.metastore.ObjectStore.getAllTokenIdentifiers(ObjectStore.java:6517)
 
{code}



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to