HDFS-2616. Change DatanodeProtocol#sendHeartbeat() to return HeartbeatResponse. (suresh)
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/HDFS-1623@1208987 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
1e346aa829
commit
8dbb523768
|
@ -31,3 +31,5 @@ HDFS-2591. MiniDFSCluster support to mix and match federation with HA (todd)
|
||||||
HDFS-1975. Support for sharing the namenode state from active to standby. (jitendra, atm, todd)
|
HDFS-1975. Support for sharing the namenode state from active to standby. (jitendra, atm, todd)
|
||||||
|
|
||||||
HDFS-1971. Send block report from datanode to both active and standby namenodes. (sanjay, todd via suresh)
|
HDFS-1971. Send block report from datanode to both active and standby namenodes. (sanjay, todd via suresh)
|
||||||
|
|
||||||
|
HDFS-2616. Change DatanodeProtocol#sendHeartbeat() to return HeartbeatResponse. (suresh)
|
||||||
|
|
|
@ -42,6 +42,7 @@ import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DisallowedDatanodeException;
|
import org.apache.hadoop.hdfs.server.protocol.DisallowedDatanodeException;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.ReceivedDeletedBlockInfo;
|
import org.apache.hadoop.hdfs.server.protocol.ReceivedDeletedBlockInfo;
|
||||||
import org.apache.hadoop.ipc.RPC;
|
import org.apache.hadoop.ipc.RPC;
|
||||||
|
@ -333,7 +334,7 @@ class BPServiceActor implements Runnable {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
DatanodeCommand [] sendHeartBeat() throws IOException {
|
HeartbeatResponse sendHeartBeat() throws IOException {
|
||||||
LOG.info("heartbeat: " + this);
|
LOG.info("heartbeat: " + this);
|
||||||
// TODO: saw an NPE here - maybe if the two BPOS register at
|
// TODO: saw an NPE here - maybe if the two BPOS register at
|
||||||
// same time, this one won't block on the other one?
|
// same time, this one won't block on the other one?
|
||||||
|
@ -420,16 +421,17 @@ class BPServiceActor implements Runnable {
|
||||||
//
|
//
|
||||||
lastHeartbeat = startTime;
|
lastHeartbeat = startTime;
|
||||||
if (!dn.areHeartbeatsDisabledForTests()) {
|
if (!dn.areHeartbeatsDisabledForTests()) {
|
||||||
DatanodeCommand[] cmds = sendHeartBeat();
|
HeartbeatResponse resp = sendHeartBeat();
|
||||||
dn.getMetrics().addHeartbeat(now() - startTime);
|
dn.getMetrics().addHeartbeat(now() - startTime);
|
||||||
|
|
||||||
long startProcessCommands = now();
|
long startProcessCommands = now();
|
||||||
if (!processCommand(cmds))
|
if (!processCommand(resp.getCommands()))
|
||||||
continue;
|
continue;
|
||||||
long endProcessCommands = now();
|
long endProcessCommands = now();
|
||||||
if (endProcessCommands - startProcessCommands > 2000) {
|
if (endProcessCommands - startProcessCommands > 2000) {
|
||||||
LOG.info("Took " + (endProcessCommands - startProcessCommands) +
|
LOG.info("Took " + (endProcessCommands - startProcessCommands)
|
||||||
"ms to process " + cmds.length + " commands from NN");
|
+ "ms to process " + resp.getCommands().length
|
||||||
|
+ " commands from NN");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -154,6 +154,7 @@ import org.apache.hadoop.hdfs.server.namenode.ha.EditLogTailer;
|
||||||
import org.apache.hadoop.hdfs.server.namenode.metrics.FSNamesystemMBean;
|
import org.apache.hadoop.hdfs.server.namenode.metrics.FSNamesystemMBean;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeRegistration;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
||||||
|
@ -2688,7 +2689,7 @@ public class FSNamesystem implements Namesystem, FSClusterStats,
|
||||||
* @return an array of datanode commands
|
* @return an array of datanode commands
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
DatanodeCommand[] handleHeartbeat(DatanodeRegistration nodeReg,
|
HeartbeatResponse handleHeartbeat(DatanodeRegistration nodeReg,
|
||||||
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
||||||
int xceiverCount, int xmitsInProgress, int failedVolumes)
|
int xceiverCount, int xmitsInProgress, int failedVolumes)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
|
@ -2699,16 +2700,13 @@ public class FSNamesystem implements Namesystem, FSClusterStats,
|
||||||
DatanodeCommand[] cmds = blockManager.getDatanodeManager().handleHeartbeat(
|
DatanodeCommand[] cmds = blockManager.getDatanodeManager().handleHeartbeat(
|
||||||
nodeReg, blockPoolId, capacity, dfsUsed, remaining, blockPoolUsed,
|
nodeReg, blockPoolId, capacity, dfsUsed, remaining, blockPoolUsed,
|
||||||
xceiverCount, maxTransfer, failedVolumes);
|
xceiverCount, maxTransfer, failedVolumes);
|
||||||
if (cmds != null) {
|
if (cmds == null) {
|
||||||
return cmds;
|
|
||||||
}
|
|
||||||
|
|
||||||
//check distributed upgrade
|
|
||||||
DatanodeCommand cmd = upgradeManager.getBroadcastCommand();
|
DatanodeCommand cmd = upgradeManager.getBroadcastCommand();
|
||||||
if (cmd != null) {
|
if (cmd != null) {
|
||||||
return new DatanodeCommand[] {cmd};
|
cmds = new DatanodeCommand[] {cmd};
|
||||||
}
|
}
|
||||||
return null;
|
}
|
||||||
|
return new HeartbeatResponse(cmds);
|
||||||
} finally {
|
} finally {
|
||||||
readUnlock();
|
readUnlock();
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,6 +75,7 @@ import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.FinalizeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.FinalizeCommand;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocol;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocol;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocols;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocols;
|
||||||
|
@ -857,7 +858,7 @@ class NameNodeRpcServer implements NamenodeProtocols {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override // DatanodeProtocol
|
@Override // DatanodeProtocol
|
||||||
public DatanodeCommand[] sendHeartbeat(DatanodeRegistration nodeReg,
|
public HeartbeatResponse sendHeartbeat(DatanodeRegistration nodeReg,
|
||||||
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
||||||
int xmitsInProgress, int xceiverCount, int failedVolumes)
|
int xmitsInProgress, int xceiverCount, int failedVolumes)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
|
|
|
@ -22,8 +22,8 @@ import java.io.*;
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
||||||
import org.apache.hadoop.hdfs.protocol.ExtendedBlock;
|
|
||||||
import org.apache.hadoop.hdfs.protocol.DatanodeID;
|
import org.apache.hadoop.hdfs.protocol.DatanodeID;
|
||||||
|
import org.apache.hadoop.hdfs.protocol.ExtendedBlock;
|
||||||
import org.apache.hadoop.hdfs.protocol.LocatedBlock;
|
import org.apache.hadoop.hdfs.protocol.LocatedBlock;
|
||||||
import org.apache.hadoop.hdfs.protocolR23Compatible.ClientNamenodeWireProtocol;
|
import org.apache.hadoop.hdfs.protocolR23Compatible.ClientNamenodeWireProtocol;
|
||||||
import org.apache.hadoop.hdfs.server.protocolR23Compatible.DatanodeWireProtocol;
|
import org.apache.hadoop.hdfs.server.protocolR23Compatible.DatanodeWireProtocol;
|
||||||
|
@ -92,7 +92,7 @@ public interface DatanodeProtocol extends VersionedProtocol {
|
||||||
* sendHeartbeat() tells the NameNode that the DataNode is still
|
* sendHeartbeat() tells the NameNode that the DataNode is still
|
||||||
* alive and well. Includes some status info, too.
|
* alive and well. Includes some status info, too.
|
||||||
* It also gives the NameNode a chance to return
|
* It also gives the NameNode a chance to return
|
||||||
* an array of "DatanodeCommand" objects.
|
* an array of "DatanodeCommand" objects in HeartbeatResponse.
|
||||||
* A DatanodeCommand tells the DataNode to invalidate local block(s),
|
* A DatanodeCommand tells the DataNode to invalidate local block(s),
|
||||||
* or to copy them to other DataNodes, etc.
|
* or to copy them to other DataNodes, etc.
|
||||||
* @param registration datanode registration information
|
* @param registration datanode registration information
|
||||||
|
@ -106,7 +106,7 @@ public interface DatanodeProtocol extends VersionedProtocol {
|
||||||
* @throws IOException on error
|
* @throws IOException on error
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
public DatanodeCommand[] sendHeartbeat(DatanodeRegistration registration,
|
public HeartbeatResponse sendHeartbeat(DatanodeRegistration registration,
|
||||||
long capacity,
|
long capacity,
|
||||||
long dfsUsed, long remaining,
|
long dfsUsed, long remaining,
|
||||||
long blockPoolUsed,
|
long blockPoolUsed,
|
||||||
|
|
|
@ -0,0 +1,73 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.hadoop.hdfs.server.protocol;
|
||||||
|
|
||||||
|
import java.io.DataInput;
|
||||||
|
import java.io.DataOutput;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
|
import org.apache.hadoop.io.ObjectWritable;
|
||||||
|
import org.apache.hadoop.io.Writable;
|
||||||
|
|
||||||
|
@InterfaceAudience.Private
|
||||||
|
@InterfaceStability.Evolving
|
||||||
|
/**
|
||||||
|
* Response to {@link DatanodeProtocol#sendHeartbeat}
|
||||||
|
*/
|
||||||
|
public class HeartbeatResponse implements Writable {
|
||||||
|
/** Commands returned from the namenode to the datanode */
|
||||||
|
private DatanodeCommand[] commands;
|
||||||
|
|
||||||
|
public HeartbeatResponse() {
|
||||||
|
// Empty constructor required for Writable
|
||||||
|
}
|
||||||
|
|
||||||
|
public HeartbeatResponse(DatanodeCommand[] cmds) {
|
||||||
|
commands = cmds;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DatanodeCommand[] getCommands() {
|
||||||
|
return commands;
|
||||||
|
}
|
||||||
|
|
||||||
|
///////////////////////////////////////////
|
||||||
|
// Writable
|
||||||
|
///////////////////////////////////////////
|
||||||
|
@Override
|
||||||
|
public void write(DataOutput out) throws IOException {
|
||||||
|
int length = commands == null ? 0 : commands.length;
|
||||||
|
out.writeInt(length);
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
ObjectWritable.writeObject(out, commands[i], commands[i].getClass(),
|
||||||
|
null, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void readFields(DataInput in) throws IOException {
|
||||||
|
int length = in.readInt();
|
||||||
|
commands = new DatanodeCommand[length];
|
||||||
|
ObjectWritable objectWritable = new ObjectWritable();
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
commands[i] = (DatanodeCommand) ObjectWritable.readObject(in,
|
||||||
|
objectWritable, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -110,11 +110,11 @@ public class DatanodeProtocolServerSideTranslatorR23 implements
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DatanodeCommandWritable[] sendHeartbeat(
|
public HeartbeatResponseWritable sendHeartbeat(
|
||||||
DatanodeRegistrationWritable registration, long capacity, long dfsUsed,
|
DatanodeRegistrationWritable registration, long capacity, long dfsUsed,
|
||||||
long remaining, long blockPoolUsed, int xmitsInProgress,
|
long remaining, long blockPoolUsed, int xmitsInProgress,
|
||||||
int xceiverCount, int failedVolumes) throws IOException {
|
int xceiverCount, int failedVolumes) throws IOException {
|
||||||
return DatanodeCommandWritable.convert(server.sendHeartbeat(
|
return HeartbeatResponseWritable.convert(server.sendHeartbeat(
|
||||||
registration.convert(), capacity, dfsUsed, remaining, blockPoolUsed,
|
registration.convert(), capacity, dfsUsed, remaining, blockPoolUsed,
|
||||||
xmitsInProgress, xceiverCount, failedVolumes));
|
xmitsInProgress, xceiverCount, failedVolumes));
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,6 +40,7 @@ import org.apache.hadoop.hdfs.server.namenode.NameNode;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeProtocol;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
import org.apache.hadoop.hdfs.server.protocol.NamespaceInfo;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.ReceivedDeletedBlockInfo;
|
import org.apache.hadoop.hdfs.server.protocol.ReceivedDeletedBlockInfo;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.UpgradeCommand;
|
import org.apache.hadoop.hdfs.server.protocol.UpgradeCommand;
|
||||||
|
@ -130,14 +131,14 @@ public class DatanodeProtocolTranslatorR23 implements
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DatanodeCommand[] sendHeartbeat(DatanodeRegistration registration,
|
public HeartbeatResponse sendHeartbeat(DatanodeRegistration registration,
|
||||||
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
long capacity, long dfsUsed, long remaining, long blockPoolUsed,
|
||||||
int xmitsInProgress, int xceiverCount, int failedVolumes)
|
int xmitsInProgress, int xceiverCount, int failedVolumes)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
return DatanodeCommandWritable.convert(rpcProxy.sendHeartbeat(
|
return rpcProxy.sendHeartbeat(
|
||||||
DatanodeRegistrationWritable.convert(registration), capacity,
|
DatanodeRegistrationWritable.convert(registration), capacity, dfsUsed,
|
||||||
dfsUsed, remaining, blockPoolUsed, xmitsInProgress, xceiverCount,
|
remaining, blockPoolUsed, xmitsInProgress, xceiverCount, failedVolumes)
|
||||||
failedVolumes));
|
.convert();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -99,7 +99,7 @@ public interface DatanodeWireProtocol extends VersionedProtocol {
|
||||||
* @throws IOException on error
|
* @throws IOException on error
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
public DatanodeCommandWritable[] sendHeartbeat(
|
public HeartbeatResponseWritable sendHeartbeat(
|
||||||
DatanodeRegistrationWritable registration, long capacity, long dfsUsed,
|
DatanodeRegistrationWritable registration, long capacity, long dfsUsed,
|
||||||
long remaining, long blockPoolUsed, int xmitsInProgress,
|
long remaining, long blockPoolUsed, int xmitsInProgress,
|
||||||
int xceiverCount, int failedVolumes) throws IOException;
|
int xceiverCount, int failedVolumes) throws IOException;
|
||||||
|
|
|
@ -0,0 +1,76 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.hadoop.hdfs.server.protocolR23Compatible;
|
||||||
|
|
||||||
|
import java.io.DataInput;
|
||||||
|
import java.io.DataOutput;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
|
import org.apache.hadoop.io.ObjectWritable;
|
||||||
|
import org.apache.hadoop.io.Writable;
|
||||||
|
|
||||||
|
@InterfaceAudience.Private
|
||||||
|
@InterfaceStability.Evolving
|
||||||
|
public class HeartbeatResponseWritable implements Writable {
|
||||||
|
private DatanodeCommandWritable[] commands;
|
||||||
|
|
||||||
|
public HeartbeatResponseWritable() {
|
||||||
|
// Empty constructor for Writable
|
||||||
|
}
|
||||||
|
|
||||||
|
public HeartbeatResponseWritable(DatanodeCommandWritable[] cmds) {
|
||||||
|
commands = cmds;
|
||||||
|
}
|
||||||
|
|
||||||
|
public HeartbeatResponse convert() {
|
||||||
|
return new HeartbeatResponse(DatanodeCommandWritable.convert(commands));
|
||||||
|
}
|
||||||
|
|
||||||
|
///////////////////////////////////////////
|
||||||
|
// Writable
|
||||||
|
///////////////////////////////////////////
|
||||||
|
@Override
|
||||||
|
public void write(DataOutput out) throws IOException {
|
||||||
|
int length = commands == null ? 0 : commands.length;
|
||||||
|
out.writeInt(length);
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
ObjectWritable.writeObject(out, commands[i], commands[i].getClass(),
|
||||||
|
null, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void readFields(DataInput in) throws IOException {
|
||||||
|
int length = in.readInt();
|
||||||
|
commands = new DatanodeCommandWritable[length];
|
||||||
|
ObjectWritable objectWritable = new ObjectWritable();
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
commands[i] = (DatanodeCommandWritable) ObjectWritable.readObject(in,
|
||||||
|
objectWritable, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static HeartbeatResponseWritable convert(
|
||||||
|
HeartbeatResponse resp) {
|
||||||
|
return new HeartbeatResponseWritable(DatanodeCommandWritable.convert(resp
|
||||||
|
.getCommands()));
|
||||||
|
}
|
||||||
|
}
|
|
@ -41,7 +41,7 @@ import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
public class TestHeartbeatHandling extends TestCase {
|
public class TestHeartbeatHandling extends TestCase {
|
||||||
/**
|
/**
|
||||||
* Test if
|
* Test if
|
||||||
* {@link FSNamesystem#handleHeartbeat(DatanodeRegistration, long, long, long, long, int, int)}
|
* {@link FSNamesystem#handleHeartbeat}
|
||||||
* can pick up replication and/or invalidate requests and observes the max
|
* can pick up replication and/or invalidate requests and observes the max
|
||||||
* limit
|
* limit
|
||||||
*/
|
*/
|
||||||
|
@ -75,7 +75,8 @@ public class TestHeartbeatHandling extends TestCase {
|
||||||
dd.addBlockToBeReplicated(
|
dd.addBlockToBeReplicated(
|
||||||
new Block(i, 0, GenerationStamp.FIRST_VALID_STAMP), ONE_TARGET);
|
new Block(i, 0, GenerationStamp.FIRST_VALID_STAMP), ONE_TARGET);
|
||||||
}
|
}
|
||||||
DatanodeCommand[]cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem);
|
DatanodeCommand[] cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd,
|
||||||
|
namesystem).getCommands();
|
||||||
assertEquals(1, cmds.length);
|
assertEquals(1, cmds.length);
|
||||||
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
||||||
assertEquals(MAX_REPLICATE_LIMIT, ((BlockCommand)cmds[0]).getBlocks().length);
|
assertEquals(MAX_REPLICATE_LIMIT, ((BlockCommand)cmds[0]).getBlocks().length);
|
||||||
|
@ -85,26 +86,30 @@ public class TestHeartbeatHandling extends TestCase {
|
||||||
blockList.add(new Block(i, 0, GenerationStamp.FIRST_VALID_STAMP));
|
blockList.add(new Block(i, 0, GenerationStamp.FIRST_VALID_STAMP));
|
||||||
}
|
}
|
||||||
dd.addBlocksToBeInvalidated(blockList);
|
dd.addBlocksToBeInvalidated(blockList);
|
||||||
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem);
|
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem)
|
||||||
|
.getCommands();
|
||||||
assertEquals(2, cmds.length);
|
assertEquals(2, cmds.length);
|
||||||
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
||||||
assertEquals(MAX_REPLICATE_LIMIT, ((BlockCommand)cmds[0]).getBlocks().length);
|
assertEquals(MAX_REPLICATE_LIMIT, ((BlockCommand)cmds[0]).getBlocks().length);
|
||||||
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[1].getAction());
|
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[1].getAction());
|
||||||
assertEquals(MAX_INVALIDATE_LIMIT, ((BlockCommand)cmds[1]).getBlocks().length);
|
assertEquals(MAX_INVALIDATE_LIMIT, ((BlockCommand)cmds[1]).getBlocks().length);
|
||||||
|
|
||||||
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem);
|
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem)
|
||||||
|
.getCommands();
|
||||||
assertEquals(2, cmds.length);
|
assertEquals(2, cmds.length);
|
||||||
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
assertEquals(DatanodeProtocol.DNA_TRANSFER, cmds[0].getAction());
|
||||||
assertEquals(REMAINING_BLOCKS, ((BlockCommand)cmds[0]).getBlocks().length);
|
assertEquals(REMAINING_BLOCKS, ((BlockCommand)cmds[0]).getBlocks().length);
|
||||||
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[1].getAction());
|
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[1].getAction());
|
||||||
assertEquals(MAX_INVALIDATE_LIMIT, ((BlockCommand)cmds[1]).getBlocks().length);
|
assertEquals(MAX_INVALIDATE_LIMIT, ((BlockCommand)cmds[1]).getBlocks().length);
|
||||||
|
|
||||||
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem);
|
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem)
|
||||||
|
.getCommands();
|
||||||
assertEquals(1, cmds.length);
|
assertEquals(1, cmds.length);
|
||||||
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[0].getAction());
|
assertEquals(DatanodeProtocol.DNA_INVALIDATE, cmds[0].getAction());
|
||||||
assertEquals(REMAINING_BLOCKS, ((BlockCommand)cmds[0]).getBlocks().length);
|
assertEquals(REMAINING_BLOCKS, ((BlockCommand)cmds[0]).getBlocks().length);
|
||||||
|
|
||||||
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem);
|
cmds = NameNodeAdapter.sendHeartBeat(nodeReg, dd, namesystem)
|
||||||
|
.getCommands();
|
||||||
assertEquals(null, cmds);
|
assertEquals(null, cmds);
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
|
|
|
@ -25,8 +25,6 @@ import java.util.Arrays;
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import javax.security.auth.login.LoginException;
|
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.commons.logging.impl.Log4JLogger;
|
import org.apache.commons.logging.impl.Log4JLogger;
|
||||||
|
@ -78,7 +76,7 @@ import org.apache.log4j.LogManager;
|
||||||
* <li>-logLevel L specifies the logging level when the benchmark runs.
|
* <li>-logLevel L specifies the logging level when the benchmark runs.
|
||||||
* The default logging level is {@link Level#ERROR}.</li>
|
* The default logging level is {@link Level#ERROR}.</li>
|
||||||
* <li>-UGCacheRefreshCount G will cause the benchmark to call
|
* <li>-UGCacheRefreshCount G will cause the benchmark to call
|
||||||
* {@link NameNode#refreshUserToGroupsMappings()} after
|
* {@link NameNodeRpcServer#refreshUserToGroupsMappings} after
|
||||||
* every G operations, which purges the name-node's user group cache.
|
* every G operations, which purges the name-node's user group cache.
|
||||||
* By default the refresh is never called.</li>
|
* By default the refresh is never called.</li>
|
||||||
* <li>-keepResults do not clean up the name-space after execution.</li>
|
* <li>-keepResults do not clean up the name-space after execution.</li>
|
||||||
|
@ -104,7 +102,7 @@ public class NNThroughputBenchmark {
|
||||||
static NameNode nameNode;
|
static NameNode nameNode;
|
||||||
static NamenodeProtocols nameNodeProto;
|
static NamenodeProtocols nameNodeProto;
|
||||||
|
|
||||||
NNThroughputBenchmark(Configuration conf) throws IOException, LoginException {
|
NNThroughputBenchmark(Configuration conf) throws IOException {
|
||||||
config = conf;
|
config = conf;
|
||||||
// We do not need many handlers, since each thread simulates a handler
|
// We do not need many handlers, since each thread simulates a handler
|
||||||
// by calling name-node methods directly
|
// by calling name-node methods directly
|
||||||
|
@ -125,7 +123,7 @@ public class NNThroughputBenchmark {
|
||||||
nameNodeProto = nameNode.getRpcServer();
|
nameNodeProto = nameNode.getRpcServer();
|
||||||
}
|
}
|
||||||
|
|
||||||
void close() throws IOException {
|
void close() {
|
||||||
nameNode.stop();
|
nameNode.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -806,7 +804,8 @@ public class NNThroughputBenchmark {
|
||||||
// register datanode
|
// register datanode
|
||||||
// TODO:FEDERATION currently a single block pool is supported
|
// TODO:FEDERATION currently a single block pool is supported
|
||||||
DatanodeCommand[] cmds = nameNodeProto.sendHeartbeat(dnRegistration,
|
DatanodeCommand[] cmds = nameNodeProto.sendHeartbeat(dnRegistration,
|
||||||
DF_CAPACITY, DF_USED, DF_CAPACITY - DF_USED, DF_USED, 0, 0, 0);
|
DF_CAPACITY, DF_USED, DF_CAPACITY - DF_USED, DF_USED, 0, 0, 0)
|
||||||
|
.getCommands();
|
||||||
if(cmds != null) {
|
if(cmds != null) {
|
||||||
for (DatanodeCommand cmd : cmds ) {
|
for (DatanodeCommand cmd : cmds ) {
|
||||||
if(LOG.isDebugEnabled()) {
|
if(LOG.isDebugEnabled()) {
|
||||||
|
@ -851,7 +850,8 @@ public class NNThroughputBenchmark {
|
||||||
// register datanode
|
// register datanode
|
||||||
// TODO:FEDERATION currently a single block pool is supported
|
// TODO:FEDERATION currently a single block pool is supported
|
||||||
DatanodeCommand[] cmds = nameNodeProto.sendHeartbeat(dnRegistration,
|
DatanodeCommand[] cmds = nameNodeProto.sendHeartbeat(dnRegistration,
|
||||||
DF_CAPACITY, DF_USED, DF_CAPACITY - DF_USED, DF_USED, 0, 0, 0);
|
DF_CAPACITY, DF_USED, DF_CAPACITY - DF_USED, DF_USED, 0, 0, 0)
|
||||||
|
.getCommands();
|
||||||
if (cmds != null) {
|
if (cmds != null) {
|
||||||
for (DatanodeCommand cmd : cmds) {
|
for (DatanodeCommand cmd : cmds) {
|
||||||
if (cmd.getAction() == DatanodeProtocol.DNA_TRANSFER) {
|
if (cmd.getAction() == DatanodeProtocol.DNA_TRANSFER) {
|
||||||
|
@ -916,7 +916,7 @@ public class NNThroughputBenchmark {
|
||||||
config.setLong(DFSConfigKeys.DFS_HEARTBEAT_INTERVAL_KEY, 3 * 60);
|
config.setLong(DFSConfigKeys.DFS_HEARTBEAT_INTERVAL_KEY, 3 * 60);
|
||||||
parseArguments(args);
|
parseArguments(args);
|
||||||
// adjust replication to the number of data-nodes
|
// adjust replication to the number of data-nodes
|
||||||
this.replication = (short)Math.min((int)replication, getNumDatanodes());
|
this.replication = (short)Math.min(replication, getNumDatanodes());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -26,8 +26,8 @@ import org.apache.hadoop.hdfs.protocol.HdfsFileStatus;
|
||||||
import org.apache.hadoop.hdfs.protocol.LocatedBlocks;
|
import org.apache.hadoop.hdfs.protocol.LocatedBlocks;
|
||||||
import org.apache.hadoop.hdfs.security.token.delegation.DelegationTokenSecretManager;
|
import org.apache.hadoop.hdfs.security.token.delegation.DelegationTokenSecretManager;
|
||||||
import org.apache.hadoop.hdfs.server.blockmanagement.DatanodeDescriptor;
|
import org.apache.hadoop.hdfs.server.blockmanagement.DatanodeDescriptor;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeCommand;
|
|
||||||
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
||||||
|
import org.apache.hadoop.hdfs.server.protocol.HeartbeatResponse;
|
||||||
import org.apache.hadoop.ipc.Server;
|
import org.apache.hadoop.ipc.Server;
|
||||||
import org.apache.hadoop.security.AccessControlException;
|
import org.apache.hadoop.security.AccessControlException;
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ public class NameNodeAdapter {
|
||||||
return ns.getDelegationTokenSecretManager();
|
return ns.getDelegationTokenSecretManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DatanodeCommand[] sendHeartBeat(DatanodeRegistration nodeReg,
|
public static HeartbeatResponse sendHeartBeat(DatanodeRegistration nodeReg,
|
||||||
DatanodeDescriptor dd, FSNamesystem namesystem) throws IOException {
|
DatanodeDescriptor dd, FSNamesystem namesystem) throws IOException {
|
||||||
return namesystem.handleHeartbeat(nodeReg, dd.getCapacity(),
|
return namesystem.handleHeartbeat(nodeReg, dd.getCapacity(),
|
||||||
dd.getDfsUsed(), dd.getRemaining(), dd.getBlockPoolUsed(), 0, 0, 0);
|
dd.getDfsUsed(), dd.getRemaining(), dd.getBlockPoolUsed(), 0, 0, 0);
|
||||||
|
|
|
@ -128,7 +128,8 @@ public class TestDeadDatanode {
|
||||||
|
|
||||||
// Ensure heartbeat from dead datanode is rejected with a command
|
// Ensure heartbeat from dead datanode is rejected with a command
|
||||||
// that asks datanode to register again
|
// that asks datanode to register again
|
||||||
DatanodeCommand[] cmd = dnp.sendHeartbeat(reg, 0, 0, 0, 0, 0, 0, 0);
|
DatanodeCommand[] cmd = dnp.sendHeartbeat(reg, 0, 0, 0, 0, 0, 0, 0)
|
||||||
|
.getCommands();
|
||||||
Assert.assertEquals(1, cmd.length);
|
Assert.assertEquals(1, cmd.length);
|
||||||
Assert.assertEquals(cmd[0].getAction(), RegisterCommand.REGISTER
|
Assert.assertEquals(cmd[0].getAction(), RegisterCommand.REGISTER
|
||||||
.getAction());
|
.getAction());
|
||||||
|
|
Loading…
Reference in New Issue