You are viewing a plain text version of this content. The canonical link for it is here.
Posted to common-issues@hadoop.apache.org by "Hankó Gergely (Jira)" <ji...@apache.org> on 2020/01/21 09:13:00 UTC
[jira] [Created] (HADOOP-16819) Possible inconsistent state of
AbstractDelegationTokenSecretManager
Hankó Gergely created HADOOP-16819:
--------------------------------------
Summary: Possible inconsistent state of AbstractDelegationTokenSecretManager
Key: HADOOP-16819
URL: https://issues.apache.org/jira/browse/HADOOP-16819
Project: Hadoop Common
Issue Type: Bug
Components: security
Reporter: Hankó Gergely
[AbstractDelegationTokenSecretManager.updateCurrentKey|[https://github.com/apache/hadoop/blob/581072a8f04f7568d3560f105fd1988d3acc9e54/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java#L360]] increments the current key id and creates the new delegation key in two distinct synchronized blocks.
This means that other threads can see the class in an *inconsistent state, where the key for the current key id doesn't exist (yet)*.
For example the following method sometimes returns null when the token remover thread is between the two synchronized blocks:
{noformat}
@Override
public DelegationKey getCurrentKey() {
return getDelegationKey(getCurrentKeyId());
}{noformat}
Also it is possible that updateCurrentKey is called from multiple threads at the same time so *distinct keys can be generated with the same key id*.
This issue is suspected to be the cause of the intermittent failure of [TestLlapSignerImpl.testSigning|[https://github.com/apache/hive/blob/3c0705eaf5121c7b61f2dbe9db9545c3926f26f1/llap-server/src/test/org/apache/hadoop/hive/llap/security/TestLlapSignerImpl.java#L195]] - HIVE-22621.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)
---------------------------------------------------------------------
To unsubscribe, e-mail: common-issues-unsubscribe@hadoop.apache.org
For additional commands, e-mail: common-issues-help@hadoop.apache.org