|
@@ -865,6 +865,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
.newFixedThreadPool(changedVolumes.newLocations.size());
|
|
|
List<Future<IOException>> exceptions = Lists.newArrayList();
|
|
|
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
for (final StorageLocation location : changedVolumes.newLocations) {
|
|
|
exceptions.add(service.submit(new Callable<IOException>() {
|
|
|
@Override
|
|
@@ -964,6 +965,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
clearFailure, Joiner.on(",").join(storageLocations)));
|
|
|
|
|
|
IOException ioe = null;
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
// Remove volumes and block infos from FsDataset.
|
|
|
data.removeVolumes(storageLocations, clearFailure);
|
|
|
|
|
@@ -2040,6 +2042,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
FileInputStream fis[] = new FileInputStream[2];
|
|
|
|
|
|
try {
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
fis[0] = (FileInputStream)data.getBlockInputStream(blk, 0);
|
|
|
fis[1] = DatanodeUtil.getMetaDataInputStream(blk, data);
|
|
|
} catch (ClassCastException e) {
|
|
@@ -3069,6 +3072,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
@Override // InterDatanodeProtocol
|
|
|
public ReplicaRecoveryInfo initReplicaRecovery(RecoveringBlock rBlock)
|
|
|
throws IOException {
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
return data.initReplicaRecovery(rBlock);
|
|
|
}
|
|
|
|
|
@@ -3079,6 +3083,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
public String updateReplicaUnderRecovery(final ExtendedBlock oldBlock,
|
|
|
final long recoveryId, final long newBlockId, final long newLength)
|
|
|
throws IOException {
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
final Replica r = data.updateReplicaUnderRecovery(oldBlock,
|
|
|
recoveryId, newBlockId, newLength);
|
|
|
// Notify the namenode of the updated block info. This is important
|
|
@@ -3360,7 +3365,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
"The block pool is still running. First do a refreshNamenodes to " +
|
|
|
"shutdown the block pool service");
|
|
|
}
|
|
|
-
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
data.deleteBlockPool(blockPoolId, force);
|
|
|
}
|
|
|
|
|
@@ -3804,6 +3809,7 @@ public class DataNode extends ReconfigurableBase
|
|
|
@Override
|
|
|
public List<DatanodeVolumeInfo> getVolumeReport() throws IOException {
|
|
|
checkSuperuserPrivilege();
|
|
|
+ Preconditions.checkNotNull(data, "Storage not yet initialized");
|
|
|
Map<String, Object> volumeInfoMap = data.getVolumeInfoMap();
|
|
|
if (volumeInfoMap == null) {
|
|
|
LOG.warn("DataNode volume info not available.");
|