YARN-2958. Made RMStateStore not update the last sequence number when updating the delegation token. Contributed by Varun Saxena.

This commit is contained in:
Zhijie Shen 2015-01-05 13:33:07 -08:00
parent dfd2589bcb
commit 562a701945
11 changed files with 131 additions and 144 deletions

View File

@ -311,6 +311,9 @@ Release 2.7.0 - UNRELEASED
YARN-2922. ConcurrentModificationException in CapacityScheduler's LeafQueue. YARN-2922. ConcurrentModificationException in CapacityScheduler's LeafQueue.
(Rohith Sharmaks via ozawa) (Rohith Sharmaks via ozawa)
YARN-2958. Made RMStateStore not update the last sequence number when updating the
delegation token. (Varun Saxena via zjshen)
Release 2.6.0 - 2014-11-18 Release 2.6.0 - 2014-11-18
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -60,8 +60,6 @@ import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.AM
import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.ApplicationAttemptStateDataPBImpl; import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.ApplicationAttemptStateDataPBImpl;
import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.ApplicationStateDataPBImpl; import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.ApplicationStateDataPBImpl;
import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.EpochPBImpl; import org.apache.hadoop.yarn.server.resourcemanager.recovery.records.impl.pb.EpochPBImpl;
import org.apache.hadoop.yarn.util.ConverterUtils;
import com.google.common.annotations.VisibleForTesting; import com.google.common.annotations.VisibleForTesting;
@Private @Private
@ -452,11 +450,10 @@ public class FileSystemRMStateStore extends RMStateStore {
} }
@Override @Override
public synchronized void storeRMDelegationTokenAndSequenceNumberState( public synchronized void storeRMDelegationTokenState(
RMDelegationTokenIdentifier identifier, Long renewDate, RMDelegationTokenIdentifier identifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
storeOrUpdateRMDelegationTokenAndSequenceNumberState( storeOrUpdateRMDelegationTokenState(identifier, renewDate, false);
identifier, renewDate,latestSequenceNumber, false);
} }
@Override @Override
@ -469,16 +466,15 @@ public class FileSystemRMStateStore extends RMStateStore {
} }
@Override @Override
protected void updateRMDelegationTokenAndSequenceNumberInternal( protected void updateRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
storeOrUpdateRMDelegationTokenAndSequenceNumberState( storeOrUpdateRMDelegationTokenState(rmDTIdentifier, renewDate, true);
rmDTIdentifier, renewDate,latestSequenceNumber, true);
} }
private void storeOrUpdateRMDelegationTokenAndSequenceNumberState( private void storeOrUpdateRMDelegationTokenState(
RMDelegationTokenIdentifier identifier, Long renewDate, RMDelegationTokenIdentifier identifier, Long renewDate,
int latestSequenceNumber, boolean isUpdate) throws Exception { boolean isUpdate) throws Exception {
Path nodeCreatePath = Path nodeCreatePath =
getNodePath(rmDTSecretManagerRoot, getNodePath(rmDTSecretManagerRoot,
DELEGATION_TOKEN_PREFIX + identifier.getSequenceNumber()); DELEGATION_TOKEN_PREFIX + identifier.getSequenceNumber());
@ -490,23 +486,24 @@ public class FileSystemRMStateStore extends RMStateStore {
} else { } else {
LOG.info("Storing RMDelegationToken_" + identifier.getSequenceNumber()); LOG.info("Storing RMDelegationToken_" + identifier.getSequenceNumber());
writeFile(nodeCreatePath, identifierData.toByteArray()); writeFile(nodeCreatePath, identifierData.toByteArray());
}
// store sequence number // store sequence number
Path latestSequenceNumberPath = getNodePath(rmDTSecretManagerRoot, Path latestSequenceNumberPath = getNodePath(rmDTSecretManagerRoot,
DELEGATION_TOKEN_SEQUENCE_NUMBER_PREFIX + latestSequenceNumber); DELEGATION_TOKEN_SEQUENCE_NUMBER_PREFIX
LOG.info("Storing " + DELEGATION_TOKEN_SEQUENCE_NUMBER_PREFIX + identifier.getSequenceNumber());
+ latestSequenceNumber); LOG.info("Storing " + DELEGATION_TOKEN_SEQUENCE_NUMBER_PREFIX
if (dtSequenceNumberPath == null) { + identifier.getSequenceNumber());
if (!createFile(latestSequenceNumberPath)) { if (dtSequenceNumberPath == null) {
throw new Exception("Failed to create " + latestSequenceNumberPath); if (!createFile(latestSequenceNumberPath)) {
} throw new Exception("Failed to create " + latestSequenceNumberPath);
} else { }
if (!renameFile(dtSequenceNumberPath, latestSequenceNumberPath)) { } else {
throw new Exception("Failed to rename " + dtSequenceNumberPath); if (!renameFile(dtSequenceNumberPath, latestSequenceNumberPath)) {
throw new Exception("Failed to rename " + dtSequenceNumberPath);
}
} }
dtSequenceNumberPath = latestSequenceNumberPath;
} }
dtSequenceNumberPath = latestSequenceNumberPath;
} }
@Override @Override

View File

@ -544,31 +544,30 @@ public class LeveldbRMStateStore extends RMStateStore {
throw new IOException(e); throw new IOException(e);
} }
} }
@Override private void storeOrUpdateRMDT(RMDelegationTokenIdentifier tokenId,
protected void storeRMDelegationTokenAndSequenceNumberState( Long renewDate, boolean isUpdate) throws IOException {
RMDelegationTokenIdentifier tokenId, Long renewDate,
int latestSequenceNumber) throws IOException {
String tokenKey = getRMDTTokenNodeKey(tokenId); String tokenKey = getRMDTTokenNodeKey(tokenId);
RMDelegationTokenIdentifierData tokenData = RMDelegationTokenIdentifierData tokenData =
new RMDelegationTokenIdentifierData(tokenId, renewDate); new RMDelegationTokenIdentifierData(tokenId, renewDate);
ByteArrayOutputStream bs = new ByteArrayOutputStream();
DataOutputStream ds = new DataOutputStream(bs);
try {
ds.writeInt(latestSequenceNumber);
} finally {
ds.close();
}
if (LOG.isDebugEnabled()) { if (LOG.isDebugEnabled()) {
LOG.debug("Storing token to " + tokenKey); LOG.debug("Storing token to " + tokenKey);
LOG.debug("Storing " + latestSequenceNumber + " to "
+ RM_DT_SEQUENCE_NUMBER_KEY);
} }
try { try {
WriteBatch batch = db.createWriteBatch(); WriteBatch batch = db.createWriteBatch();
try { try {
batch.put(bytes(tokenKey), tokenData.toByteArray()); batch.put(bytes(tokenKey), tokenData.toByteArray());
batch.put(bytes(RM_DT_SEQUENCE_NUMBER_KEY), bs.toByteArray()); if(!isUpdate) {
ByteArrayOutputStream bs = new ByteArrayOutputStream();
try (DataOutputStream ds = new DataOutputStream(bs)) {
ds.writeInt(tokenId.getSequenceNumber());
}
if (LOG.isDebugEnabled()) {
LOG.debug("Storing " + tokenId.getSequenceNumber() + " to "
+ RM_DT_SEQUENCE_NUMBER_KEY);
}
batch.put(bytes(RM_DT_SEQUENCE_NUMBER_KEY), bs.toByteArray());
}
db.write(batch); db.write(batch);
} finally { } finally {
batch.close(); batch.close();
@ -579,11 +578,17 @@ public class LeveldbRMStateStore extends RMStateStore {
} }
@Override @Override
protected void updateRMDelegationTokenAndSequenceNumberInternal( protected void storeRMDelegationTokenState(
RMDelegationTokenIdentifier tokenId, Long renewDate, RMDelegationTokenIdentifier tokenId, Long renewDate)
int latestSequenceNumber) throws IOException { throws IOException {
storeRMDelegationTokenAndSequenceNumberState(tokenId, renewDate, storeOrUpdateRMDT(tokenId, renewDate, false);
latestSequenceNumber); }
@Override
protected void updateRMDelegationTokenState(
RMDelegationTokenIdentifier tokenId, Long renewDate)
throws IOException {
storeOrUpdateRMDT(tokenId, renewDate, true);
} }
@Override @Override

View File

@ -149,23 +149,30 @@ public class MemoryRMStateStore extends RMStateStore {
} }
} }
@Override private void storeOrUpdateRMDT(RMDelegationTokenIdentifier rmDTIdentifier,
public synchronized void storeRMDelegationTokenAndSequenceNumberState( Long renewDate, boolean isUpdate) throws Exception {
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate,
int latestSequenceNumber) throws Exception {
Map<RMDelegationTokenIdentifier, Long> rmDTState = Map<RMDelegationTokenIdentifier, Long> rmDTState =
state.rmSecretManagerState.getTokenState(); state.rmSecretManagerState.getTokenState();
if (rmDTState.containsKey(rmDTIdentifier)) { if (rmDTState.containsKey(rmDTIdentifier)) {
IOException e = new IOException("RMDelegationToken: " + rmDTIdentifier IOException e = new IOException("RMDelegationToken: " + rmDTIdentifier
+ "is already stored."); + "is already stored.");
LOG.info("Error storing info for RMDelegationToken: " + rmDTIdentifier, e); LOG.info("Error storing info for RMDelegationToken: " + rmDTIdentifier, e);
throw e; throw e;
} }
rmDTState.put(rmDTIdentifier, renewDate); rmDTState.put(rmDTIdentifier, renewDate);
state.rmSecretManagerState.dtSequenceNumber = latestSequenceNumber; if(!isUpdate) {
state.rmSecretManagerState.dtSequenceNumber =
rmDTIdentifier.getSequenceNumber();
}
LOG.info("Store RMDT with sequence number " LOG.info("Store RMDT with sequence number "
+ rmDTIdentifier.getSequenceNumber() + rmDTIdentifier.getSequenceNumber());
+ ". And the latest sequence number is " + latestSequenceNumber); }
@Override
public synchronized void storeRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
throws Exception {
storeOrUpdateRMDT(rmDTIdentifier, renewDate, false);
} }
@Override @Override
@ -179,12 +186,11 @@ public class MemoryRMStateStore extends RMStateStore {
} }
@Override @Override
protected void updateRMDelegationTokenAndSequenceNumberInternal( protected void updateRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
removeRMDelegationTokenState(rmDTIdentifier); removeRMDelegationTokenState(rmDTIdentifier);
storeRMDelegationTokenAndSequenceNumberState( storeOrUpdateRMDT(rmDTIdentifier, renewDate, true);
rmDTIdentifier, renewDate, latestSequenceNumber);
LOG.info("Update RMDT with sequence number " LOG.info("Update RMDT with sequence number "
+ rmDTIdentifier.getSequenceNumber()); + rmDTIdentifier.getSequenceNumber());
} }

View File

@ -77,9 +77,9 @@ public class NullRMStateStore extends RMStateStore {
} }
@Override @Override
public void storeRMDelegationTokenAndSequenceNumberState( public void storeRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
// Do nothing // Do nothing
} }
@ -90,9 +90,9 @@ public class NullRMStateStore extends RMStateStore {
} }
@Override @Override
protected void updateRMDelegationTokenAndSequenceNumberInternal( protected void updateRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
// Do nothing // Do nothing
} }

View File

@ -296,9 +296,8 @@ public abstract class RMStateStore extends AbstractService {
RMStateStoreRMDTEvent dtEvent = (RMStateStoreRMDTEvent) event; RMStateStoreRMDTEvent dtEvent = (RMStateStoreRMDTEvent) event;
try { try {
LOG.info("Storing RMDelegationToken and SequenceNumber"); LOG.info("Storing RMDelegationToken and SequenceNumber");
store.storeRMDelegationTokenAndSequenceNumberState( store.storeRMDelegationTokenState(
dtEvent.getRmDTIdentifier(), dtEvent.getRenewDate(), dtEvent.getRmDTIdentifier(), dtEvent.getRenewDate());
dtEvent.getLatestSequenceNumber());
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error While Storing RMDelegationToken and SequenceNumber ", LOG.error("Error While Storing RMDelegationToken and SequenceNumber ",
e); e);
@ -341,9 +340,8 @@ public abstract class RMStateStore extends AbstractService {
RMStateStoreRMDTEvent dtEvent = (RMStateStoreRMDTEvent) event; RMStateStoreRMDTEvent dtEvent = (RMStateStoreRMDTEvent) event;
try { try {
LOG.info("Updating RMDelegationToken and SequenceNumber"); LOG.info("Updating RMDelegationToken and SequenceNumber");
store.updateRMDelegationTokenAndSequenceNumberInternal( store.updateRMDelegationTokenState(
dtEvent.getRmDTIdentifier(), dtEvent.getRenewDate(), dtEvent.getRmDTIdentifier(), dtEvent.getRenewDate());
dtEvent.getLatestSequenceNumber());
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error While Updating RMDelegationToken and SequenceNumber ", LOG.error("Error While Updating RMDelegationToken and SequenceNumber ",
e); e);
@ -672,11 +670,10 @@ public abstract class RMStateStore extends AbstractService {
* RMDTSecretManager call this to store the state of a delegation token * RMDTSecretManager call this to store the state of a delegation token
* and sequence number * and sequence number
*/ */
public void storeRMDelegationTokenAndSequenceNumber( public void storeRMDelegationToken(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate) {
int latestSequenceNumber) {
handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, renewDate, handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, renewDate,
latestSequenceNumber, RMStateStoreEventType.STORE_DELEGATION_TOKEN)); RMStateStoreEventType.STORE_DELEGATION_TOKEN));
} }
/** /**
@ -684,17 +681,17 @@ public abstract class RMStateStore extends AbstractService {
* Derived classes must implement this method to store the state of * Derived classes must implement this method to store the state of
* RMDelegationToken and sequence number * RMDelegationToken and sequence number
*/ */
protected abstract void storeRMDelegationTokenAndSequenceNumberState( protected abstract void storeRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception; throws Exception;
/** /**
* RMDTSecretManager call this to remove the state of a delegation token * RMDTSecretManager call this to remove the state of a delegation token
*/ */
public void removeRMDelegationToken( public void removeRMDelegationToken(
RMDelegationTokenIdentifier rmDTIdentifier, int sequenceNumber) { RMDelegationTokenIdentifier rmDTIdentifier) {
handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, null, handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, null,
sequenceNumber, RMStateStoreEventType.REMOVE_DELEGATION_TOKEN)); RMStateStoreEventType.REMOVE_DELEGATION_TOKEN));
} }
/** /**
@ -708,11 +705,10 @@ public abstract class RMStateStore extends AbstractService {
* RMDTSecretManager call this to update the state of a delegation token * RMDTSecretManager call this to update the state of a delegation token
* and sequence number * and sequence number
*/ */
public void updateRMDelegationTokenAndSequenceNumber( public void updateRMDelegationToken(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate) {
int latestSequenceNumber) {
handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, renewDate, handleStoreEvent(new RMStateStoreRMDTEvent(rmDTIdentifier, renewDate,
latestSequenceNumber, RMStateStoreEventType.UPDATE_DELEGATION_TOKEN)); RMStateStoreEventType.UPDATE_DELEGATION_TOKEN));
} }
/** /**
@ -720,9 +716,9 @@ public abstract class RMStateStore extends AbstractService {
* Derived classes must implement this method to update the state of * Derived classes must implement this method to update the state of
* RMDelegationToken and sequence number * RMDelegationToken and sequence number
*/ */
protected abstract void updateRMDelegationTokenAndSequenceNumberInternal( protected abstract void updateRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception; throws Exception;
/** /**
* RMDTSecretManager call this to store the state of a master key * RMDTSecretManager call this to store the state of a master key

View File

@ -23,18 +23,16 @@ import org.apache.hadoop.yarn.security.client.RMDelegationTokenIdentifier;
public class RMStateStoreRMDTEvent extends RMStateStoreEvent { public class RMStateStoreRMDTEvent extends RMStateStoreEvent {
private RMDelegationTokenIdentifier rmDTIdentifier; private RMDelegationTokenIdentifier rmDTIdentifier;
private Long renewDate; private Long renewDate;
private int latestSequenceNumber;
public RMStateStoreRMDTEvent(RMStateStoreEventType type) { public RMStateStoreRMDTEvent(RMStateStoreEventType type) {
super(type); super(type);
} }
public RMStateStoreRMDTEvent(RMDelegationTokenIdentifier rmDTIdentifier, public RMStateStoreRMDTEvent(RMDelegationTokenIdentifier rmDTIdentifier,
Long renewDate, int latestSequenceNumber, RMStateStoreEventType type) { Long renewDate, RMStateStoreEventType type) {
this(type); this(type);
this.rmDTIdentifier = rmDTIdentifier; this.rmDTIdentifier = rmDTIdentifier;
this.renewDate = renewDate; this.renewDate = renewDate;
this.latestSequenceNumber = latestSequenceNumber;
} }
public RMDelegationTokenIdentifier getRmDTIdentifier() { public RMDelegationTokenIdentifier getRmDTIdentifier() {
@ -44,8 +42,4 @@ public class RMStateStoreRMDTEvent extends RMStateStoreEvent {
public Long getRenewDate() { public Long getRenewDate() {
return renewDate; return renewDate;
} }
}
public int getLatestSequenceNumber() {
return latestSequenceNumber;
}
}

View File

@ -698,12 +698,11 @@ public class ZKRMStateStore extends RMStateStore {
} }
@Override @Override
protected synchronized void storeRMDelegationTokenAndSequenceNumberState( protected synchronized void storeRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
ArrayList<Op> opList = new ArrayList<Op>(); ArrayList<Op> opList = new ArrayList<Op>();
addStoreOrUpdateOps( addStoreOrUpdateOps(opList, rmDTIdentifier, renewDate, false);
opList, rmDTIdentifier, renewDate, latestSequenceNumber, false);
doMultiWithRetries(opList); doMultiWithRetries(opList);
} }
@ -727,29 +726,27 @@ public class ZKRMStateStore extends RMStateStore {
} }
@Override @Override
protected synchronized void updateRMDelegationTokenAndSequenceNumberInternal( protected synchronized void updateRMDelegationTokenState(
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate)
int latestSequenceNumber) throws Exception { throws Exception {
ArrayList<Op> opList = new ArrayList<Op>(); ArrayList<Op> opList = new ArrayList<Op>();
String nodeRemovePath = String nodeRemovePath =
getNodePath(delegationTokensRootPath, DELEGATION_TOKEN_PREFIX getNodePath(delegationTokensRootPath, DELEGATION_TOKEN_PREFIX
+ rmDTIdentifier.getSequenceNumber()); + rmDTIdentifier.getSequenceNumber());
if (existsWithRetries(nodeRemovePath, true) == null) { if (existsWithRetries(nodeRemovePath, true) == null) {
// in case znode doesn't exist // in case znode doesn't exist
addStoreOrUpdateOps( addStoreOrUpdateOps(opList, rmDTIdentifier, renewDate, false);
opList, rmDTIdentifier, renewDate, latestSequenceNumber, false);
LOG.debug("Attempted to update a non-existing znode " + nodeRemovePath); LOG.debug("Attempted to update a non-existing znode " + nodeRemovePath);
} else { } else {
// in case znode exists // in case znode exists
addStoreOrUpdateOps( addStoreOrUpdateOps(opList, rmDTIdentifier, renewDate, true);
opList, rmDTIdentifier, renewDate, latestSequenceNumber, true);
} }
doMultiWithRetries(opList); doMultiWithRetries(opList);
} }
private void addStoreOrUpdateOps(ArrayList<Op> opList, private void addStoreOrUpdateOps(ArrayList<Op> opList,
RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate, RMDelegationTokenIdentifier rmDTIdentifier, Long renewDate,
int latestSequenceNumber, boolean isUpdate) throws Exception { boolean isUpdate) throws Exception {
// store RM delegation token // store RM delegation token
String nodeCreatePath = String nodeCreatePath =
getNodePath(delegationTokensRootPath, DELEGATION_TOKEN_PREFIX getNodePath(delegationTokensRootPath, DELEGATION_TOKEN_PREFIX
@ -769,16 +766,15 @@ public class ZKRMStateStore extends RMStateStore {
} else { } else {
opList.add(Op.create(nodeCreatePath, identifierData.toByteArray(), zkAcl, opList.add(Op.create(nodeCreatePath, identifierData.toByteArray(), zkAcl,
CreateMode.PERSISTENT)); CreateMode.PERSISTENT));
// Update Sequence number only while storing DT
seqOut.writeInt(rmDTIdentifier.getSequenceNumber());
if (LOG.isDebugEnabled()) {
LOG.debug((isUpdate ? "Storing " : "Updating ") +
dtSequenceNumberPath + ". SequenceNumber: "
+ rmDTIdentifier.getSequenceNumber());
}
opList.add(Op.setData(dtSequenceNumberPath, seqOs.toByteArray(), -1));
} }
seqOut.writeInt(latestSequenceNumber);
if (LOG.isDebugEnabled()) {
LOG.debug((isUpdate ? "Storing " : "Updating ") + dtSequenceNumberPath +
". SequenceNumber: " + latestSequenceNumber);
}
opList.add(Op.setData(dtSequenceNumberPath, seqOs.toByteArray(), -1));
} finally { } finally {
seqOs.close(); seqOs.close();
} }

View File

@ -29,10 +29,8 @@ import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.classification.InterfaceAudience;
import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceAudience.Private;
import org.apache.hadoop.classification.InterfaceStability; import org.apache.hadoop.classification.InterfaceStability;
import org.apache.hadoop.security.token.SecretManager.InvalidToken;
import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager; import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager;
import org.apache.hadoop.security.token.delegation.DelegationKey; import org.apache.hadoop.security.token.delegation.DelegationKey;
import org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager.DelegationTokenInformation;
import org.apache.hadoop.util.ExitUtil; import org.apache.hadoop.util.ExitUtil;
import org.apache.hadoop.yarn.security.client.RMDelegationTokenIdentifier; import org.apache.hadoop.yarn.security.client.RMDelegationTokenIdentifier;
import org.apache.hadoop.yarn.server.resourcemanager.RMContext; import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
@ -109,8 +107,7 @@ public class RMDelegationTokenSecretManager extends
try { try {
LOG.info("storing RMDelegation token with sequence number: " LOG.info("storing RMDelegation token with sequence number: "
+ identifier.getSequenceNumber()); + identifier.getSequenceNumber());
rmContext.getStateStore().storeRMDelegationTokenAndSequenceNumber( rmContext.getStateStore().storeRMDelegationToken(identifier, renewDate);
identifier, renewDate, identifier.getSequenceNumber());
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error in storing RMDelegationToken with sequence number: " LOG.error("Error in storing RMDelegationToken with sequence number: "
+ identifier.getSequenceNumber()); + identifier.getSequenceNumber());
@ -124,11 +121,10 @@ public class RMDelegationTokenSecretManager extends
try { try {
LOG.info("updating RMDelegation token with sequence number: " LOG.info("updating RMDelegation token with sequence number: "
+ id.getSequenceNumber()); + id.getSequenceNumber());
rmContext.getStateStore().updateRMDelegationTokenAndSequenceNumber(id, rmContext.getStateStore().updateRMDelegationToken(id, renewDate);
renewDate, id.getSequenceNumber());
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error in updating persisted RMDelegationToken with sequence number: " LOG.error("Error in updating persisted RMDelegationToken" +
+ id.getSequenceNumber()); " with sequence number: " + id.getSequenceNumber());
ExitUtil.terminate(1, e); ExitUtil.terminate(1, e);
} }
} }
@ -139,8 +135,7 @@ public class RMDelegationTokenSecretManager extends
try { try {
LOG.info("removing RMDelegation token with sequence number: " LOG.info("removing RMDelegation token with sequence number: "
+ ident.getSequenceNumber()); + ident.getSequenceNumber());
rmContext.getStateStore().removeRMDelegationToken(ident, rmContext.getStateStore().removeRMDelegationToken(ident);
delegationTokenSequenceNumber);
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error in removing RMDelegationToken with sequence number: " LOG.error("Error in removing RMDelegationToken with sequence number: "
+ ident.getSequenceNumber()); + ident.getSequenceNumber());

View File

@ -411,16 +411,15 @@ public class RMStateStoreTestBase extends ClientBaseWithFixes{
RMDelegationTokenIdentifier dtId1 = RMDelegationTokenIdentifier dtId1 =
new RMDelegationTokenIdentifier(new Text("owner1"), new RMDelegationTokenIdentifier(new Text("owner1"),
new Text("renewer1"), new Text("realuser1")); new Text("renewer1"), new Text("realuser1"));
int sequenceNumber = 1111;
dtId1.setSequenceNumber(sequenceNumber);
byte[] tokenBeforeStore = dtId1.getBytes(); byte[] tokenBeforeStore = dtId1.getBytes();
Long renewDate1 = new Long(System.currentTimeMillis()); Long renewDate1 = new Long(System.currentTimeMillis());
int sequenceNumber = 1111; store.storeRMDelegationToken(dtId1, renewDate1);
store.storeRMDelegationTokenAndSequenceNumber(dtId1, renewDate1,
sequenceNumber);
modifyRMDelegationTokenState(); modifyRMDelegationTokenState();
Map<RMDelegationTokenIdentifier, Long> token1 = Map<RMDelegationTokenIdentifier, Long> token1 =
new HashMap<RMDelegationTokenIdentifier, Long>(); new HashMap<RMDelegationTokenIdentifier, Long>();
token1.put(dtId1, renewDate1); token1.put(dtId1, renewDate1);
// store delegation key; // store delegation key;
DelegationKey key = new DelegationKey(1234, 4321 , "keyBytes".getBytes()); DelegationKey key = new DelegationKey(1234, 4321 , "keyBytes".getBytes());
HashSet<DelegationKey> keySet = new HashSet<DelegationKey>(); HashSet<DelegationKey> keySet = new HashSet<DelegationKey>();
@ -440,9 +439,7 @@ public class RMStateStoreTestBase extends ClientBaseWithFixes{
// update RM delegation token; // update RM delegation token;
renewDate1 = new Long(System.currentTimeMillis()); renewDate1 = new Long(System.currentTimeMillis());
++sequenceNumber; store.updateRMDelegationToken(dtId1, renewDate1);
store.updateRMDelegationTokenAndSequenceNumber(
dtId1, renewDate1, sequenceNumber);
token1.put(dtId1, renewDate1); token1.put(dtId1, renewDate1);
RMDTSecretManagerState updateSecretManagerState = RMDTSecretManagerState updateSecretManagerState =
@ -463,7 +460,7 @@ public class RMStateStoreTestBase extends ClientBaseWithFixes{
noKeySecretManagerState.getDTSequenceNumber()); noKeySecretManagerState.getDTSequenceNumber());
// check to delete delegationToken // check to delete delegationToken
store.removeRMDelegationToken(dtId1, sequenceNumber); store.removeRMDelegationToken(dtId1);
RMDTSecretManagerState noKeyAndTokenSecretManagerState = RMDTSecretManagerState noKeyAndTokenSecretManagerState =
store.loadState().getRMDTSecretManagerState(); store.loadState().getRMDTSecretManagerState();
token1.clear(); token1.clear();

View File

@ -337,20 +337,18 @@ public class TestZKRMStateStore extends RMStateStoreTestBase {
RMDelegationTokenIdentifier dtId1 = RMDelegationTokenIdentifier dtId1 =
new RMDelegationTokenIdentifier(new Text("owner1"), new RMDelegationTokenIdentifier(new Text("owner1"),
new Text("renewer1"), new Text("realuser1")); new Text("renewer1"), new Text("realuser1"));
Long renewDate1 = new Long(System.currentTimeMillis()); Long renewDate1 = new Long(System.currentTimeMillis());
int sequenceNumber = 1111; dtId1.setSequenceNumber(1111);
store.storeRMDelegationTokenAndSequenceNumber(dtId1, renewDate1, store.storeRMDelegationToken(dtId1, renewDate1);
sequenceNumber);
assertEquals("RMStateStore should have been in fenced state", true, assertEquals("RMStateStore should have been in fenced state", true,
store.isFencedState()); store.isFencedState());
store.updateRMDelegationTokenAndSequenceNumber(dtId1, renewDate1, store.updateRMDelegationToken(dtId1, renewDate1);
sequenceNumber);
assertEquals("RMStateStore should have been in fenced state", true, assertEquals("RMStateStore should have been in fenced state", true,
store.isFencedState()); store.isFencedState());
// remove delegation key; // remove delegation key;
store.removeRMDelegationToken(dtId1, sequenceNumber); store.removeRMDelegationToken(dtId1);
assertEquals("RMStateStore should have been in fenced state", true, assertEquals("RMStateStore should have been in fenced state", true,
store.isFencedState()); store.isFencedState());