diff --git a/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClient.java b/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClient.java index 42e02f9b13..709f0dc6cb 100644 --- a/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClient.java +++ b/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClient.java @@ -93,7 +93,7 @@ public void connect() throws Exception { // read port from the data node, on failure use default configured // port. - int port = leader.getContainerPort(); + int port = leader.getPort(DatanodeDetails.Port.Name.STANDALONE).getValue(); if (port == 0) { port = config.getInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, OzoneConfigKeys.DFS_CONTAINER_IPC_PORT_DEFAULT); diff --git a/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClientGrpc.java b/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClientGrpc.java index 84790e8e71..c78702486f 100644 --- a/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClientGrpc.java +++ b/hadoop-hdds/client/src/main/java/org/apache/hadoop/hdds/scm/XceiverClientGrpc.java @@ -80,7 +80,7 @@ public void connect() throws Exception { // read port from the data node, on failure use default configured // port. - int port = leader.getContainerPort(); + int port = leader.getPort(DatanodeDetails.Port.Name.STANDALONE).getValue(); if (port == 0) { port = config.getInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, OzoneConfigKeys.DFS_CONTAINER_IPC_PORT_DEFAULT); diff --git a/hadoop-hdds/common/src/main/java/org/apache/hadoop/hdds/protocol/DatanodeDetails.java b/hadoop-hdds/common/src/main/java/org/apache/hadoop/hdds/protocol/DatanodeDetails.java index b2fa291d5a..c373e22510 100644 --- a/hadoop-hdds/common/src/main/java/org/apache/hadoop/hdds/protocol/DatanodeDetails.java +++ b/hadoop-hdds/common/src/main/java/org/apache/hadoop/hdds/protocol/DatanodeDetails.java @@ -23,6 +23,8 @@ import org.apache.hadoop.classification.InterfaceStability; import org.apache.hadoop.hdds.protocol.proto.HddsProtos; +import java.util.ArrayList; +import java.util.List; import java.util.UUID; /** @@ -42,9 +44,7 @@ public final class DatanodeDetails implements Comparable { private String ipAddress; private String hostName; - private Integer containerPort; - private Integer ratisPort; - private Integer ozoneRestPort; + private List ports; /** @@ -53,18 +53,14 @@ public final class DatanodeDetails implements Comparable { * @param uuid DataNode's UUID * @param ipAddress IP Address of this DataNode * @param hostName DataNode's hostname - * @param containerPort Container Port - * @param ratisPort Ratis Port - * @param ozoneRestPort Rest Port + * @param ports Ports used by the DataNode */ private DatanodeDetails(String uuid, String ipAddress, String hostName, - Integer containerPort, Integer ratisPort, Integer ozoneRestPort) { + List ports) { this.uuid = UUID.fromString(uuid); this.ipAddress = ipAddress; this.hostName = hostName; - this.containerPort = containerPort; - this.ratisPort = ratisPort; - this.ozoneRestPort = ozoneRestPort; + this.ports = ports; } /** @@ -122,54 +118,40 @@ public String getHostName() { } /** - * Sets the Container Port. - * @param port ContainerPort - */ - public void setContainerPort(int port) { - containerPort = port; - } - - /** - * Returns standalone container Port. + * Sets a DataNode Port. * - * @return Container Port + * @param port DataNode port */ - public int getContainerPort() { - return containerPort; + public void setPort(Port port) { + // If the port is already in the list remove it first and add the + // new/updated port value. + ports.remove(port); + ports.add(port); } /** - * Sets Ratis Port. - * @param port RatisPort + * Returns all the Ports used by DataNode. + * + * @return DataNode Ports */ - public void setRatisPort(int port) { - ratisPort = port; - } - - - /** - * Returns Ratis Port. - * @return Ratis Port - */ - public int getRatisPort() { - return ratisPort; - } - - - /** - * Sets OzoneRestPort. - * @param port OzoneRestPort - */ - public void setOzoneRestPort(int port) { - ozoneRestPort = port; + public List getPorts() { + return ports; } /** - * Returns Ozone Rest Port. - * @return OzoneRestPort + * Given the name returns port number, null if the asked port is not found. + * + * @param name Name of the port + * + * @return Port */ - public int getOzoneRestPort() { - return ozoneRestPort; + public Port getPort(Port.Name name) { + for (Port port : ports) { + if (port.getName().equals(name)) { + return port; + } + } + return null; } /** @@ -188,14 +170,9 @@ public static DatanodeDetails getFromProtoBuf( if (datanodeDetailsProto.hasHostName()) { builder.setHostName(datanodeDetailsProto.getHostName()); } - if (datanodeDetailsProto.hasContainerPort()) { - builder.setContainerPort(datanodeDetailsProto.getContainerPort()); - } - if (datanodeDetailsProto.hasRatisPort()) { - builder.setRatisPort(datanodeDetailsProto.getRatisPort()); - } - if (datanodeDetailsProto.hasOzoneRestPort()) { - builder.setOzoneRestPort(datanodeDetailsProto.getOzoneRestPort()); + for (HddsProtos.Port port : datanodeDetailsProto.getPortsList()) { + builder.addPort(newPort( + Port.Name.valueOf(port.getName().toUpperCase()), port.getValue())); } return builder.build(); } @@ -214,14 +191,11 @@ public HddsProtos.DatanodeDetailsProto getProtoBufMessage() { if (hostName != null) { builder.setHostName(hostName); } - if (containerPort != null) { - builder.setContainerPort(containerPort); - } - if (ratisPort != null) { - builder.setRatisPort(ratisPort); - } - if (ozoneRestPort != null) { - builder.setOzoneRestPort(ozoneRestPort); + for (Port port : ports) { + builder.addPorts(HddsProtos.Port.newBuilder() + .setName(port.getName().toString()) + .setValue(port.getValue()) + .build()); } return builder.build(); } @@ -268,9 +242,15 @@ public static class Builder { private String id; private String ipAddress; private String hostName; - private Integer containerPort; - private Integer ratisPort; - private Integer ozoneRestPort; + private List ports; + + /** + * Default private constructor. To create Builder instance use + * DatanodeDetails#newBuilder. + */ + private Builder() { + ports = new ArrayList<>(); + } /** * Sets the DatanodeUuid. @@ -304,36 +284,16 @@ public Builder setHostName(String host) { this.hostName = host; return this; } - /** - * Sets the ContainerPort. - * - * @param port ContainerPort - * @return DatanodeDetails.Builder - */ - public Builder setContainerPort(Integer port) { - this.containerPort = port; - return this; - } /** - * Sets the RatisPort. + * Adds a DataNode Port. + * + * @param port DataNode port * - * @param port RatisPort * @return DatanodeDetails.Builder */ - public Builder setRatisPort(Integer port) { - this.ratisPort = port; - return this; - } - - /** - * Sets the OzoneRestPort. - * - * @param port OzoneRestPort - * @return DatanodeDetails.Builder - */ - public Builder setOzoneRestPort(Integer port) { - this.ozoneRestPort = port; + public Builder addPort(Port port) { + this.ports.add(port); return this; } @@ -344,10 +304,91 @@ public Builder setOzoneRestPort(Integer port) { */ public DatanodeDetails build() { Preconditions.checkNotNull(id); - return new DatanodeDetails(id, ipAddress, hostName, containerPort, - ratisPort, ozoneRestPort); + return new DatanodeDetails(id, ipAddress, hostName, ports); } } + /** + * Constructs a new Port with name and value. + * + * @param name Name of the port + * @param value Port number + * + * @return {@code Port} instance + */ + public static Port newPort(Port.Name name, Integer value) { + return new Port(name, value); + } + + /** + * Container to hold DataNode Port details. + */ + public static class Port { + + /** + * Ports that are supported in DataNode. + */ + public enum Name { + STANDALONE, RATIS, REST + } + + private Name name; + private Integer value; + + /** + * Private constructor for constructing Port object. Use + * DatanodeDetails#newPort to create a new Port object. + * + * @param name + * @param value + */ + private Port(Name name, Integer value) { + this.name = name; + this.value = value; + } + + /** + * Returns the name of the port. + * + * @return Port name + */ + public Name getName() { + return name; + } + + /** + * Returns the port number. + * + * @return Port number + */ + public Integer getValue() { + return value; + } + + @Override + public int hashCode() { + return name.hashCode(); + } + + /** + * Ports are considered equal if they have the same name. + * + * @param anObject + * The object to compare this {@code Port} against + * @return {@code true} if the given object represents a {@code Port} + and has the same name, {@code false} otherwise + */ + @Override + public boolean equals(Object anObject) { + if (this == anObject) { + return true; + } + if (anObject instanceof Port) { + return name.equals(((Port) anObject).name); + } + return false; + } + } + } diff --git a/hadoop-hdds/common/src/main/java/org/apache/ratis/RatisHelper.java b/hadoop-hdds/common/src/main/java/org/apache/ratis/RatisHelper.java index 3a55831364..20356b3980 100644 --- a/hadoop-hdds/common/src/main/java/org/apache/ratis/RatisHelper.java +++ b/hadoop-hdds/common/src/main/java/org/apache/ratis/RatisHelper.java @@ -48,11 +48,13 @@ public interface RatisHelper { Logger LOG = LoggerFactory.getLogger(RatisHelper.class); static String toRaftPeerIdString(DatanodeDetails id) { - return id.getUuidString() + "_" + id.getRatisPort(); + return id.getUuidString() + "_" + + id.getPort(DatanodeDetails.Port.Name.RATIS); } static String toRaftPeerAddressString(DatanodeDetails id) { - return id.getIpAddress() + ":" + id.getRatisPort(); + return id.getIpAddress() + ":" + + id.getPort(DatanodeDetails.Port.Name.RATIS); } static RaftPeerId toRaftPeerId(DatanodeDetails id) { diff --git a/hadoop-hdds/common/src/main/proto/hdds.proto b/hadoop-hdds/common/src/main/proto/hdds.proto index 6ea5727963..f834c73e59 100644 --- a/hadoop-hdds/common/src/main/proto/hdds.proto +++ b/hadoop-hdds/common/src/main/proto/hdds.proto @@ -29,13 +29,15 @@ option java_generate_equals_and_hash = true; package hadoop.hdds; message DatanodeDetailsProto { - // TODO: make the port as a seperate proto message and use it here required string uuid = 1; // UUID assigned to the Datanode. required string ipAddress = 2; // IP address required string hostName = 3; // hostname - optional uint32 containerPort = 4 [default = 0]; // Ozone stand_alone protocol - optional uint32 ratisPort = 5 [default = 0]; //Ozone ratis port - optional uint32 ozoneRestPort = 6 [default = 0]; + repeated Port ports = 4; +} + +message Port { + required string name = 1; + required uint32 value = 2; } message PipelineChannel { diff --git a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServer.java b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServer.java index 7105fd7881..455df4977e 100644 --- a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServer.java +++ b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServer.java @@ -80,7 +80,8 @@ public XceiverServer(DatanodeDetails datanodeDetails, Configuration conf, + "fallback to use default port {}", this.port, e); } } - datanodeDetails.setContainerPort(port); + datanodeDetails.setPort( + DatanodeDetails.newPort(DatanodeDetails.Port.Name.STANDALONE, port)); this.storageContainer = dispatcher; } diff --git a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServerGrpc.java b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServerGrpc.java index 30a2f875f0..550fe41617 100644 --- a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServerGrpc.java +++ b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/XceiverServerGrpc.java @@ -71,7 +71,8 @@ public XceiverServerGrpc(DatanodeDetails datanodeDetails, Configuration conf, + "fallback to use default port {}", this.port, e); } } - datanodeDetails.setContainerPort(port); + datanodeDetails.setPort( + DatanodeDetails.newPort(DatanodeDetails.Port.Name.STANDALONE, port)); server = ((NettyServerBuilder) ServerBuilder.forPort(port)) .maxMessageSize(OzoneConfigKeys.DFS_CONTAINER_CHUNK_MAX_SIZE) .addService(new GrpcXceiverService(dispatcher)) diff --git a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/ratis/XceiverServerRatis.java b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/ratis/XceiverServerRatis.java index 46def09710..33c25eaf2e 100644 --- a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/ratis/XceiverServerRatis.java +++ b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/common/transport/server/ratis/XceiverServerRatis.java @@ -203,7 +203,8 @@ public static XceiverServerRatis newXceiverServerRatis( + "fallback to use default port {}", localPort, e); } } - datanodeDetails.setRatisPort(localPort); + datanodeDetails.setPort( + DatanodeDetails.newPort(DatanodeDetails.Port.Name.RATIS, localPort)); return new XceiverServerRatis(datanodeDetails, localPort, storageDir, dispatcher, ozoneConf); } diff --git a/hadoop-hdds/container-service/src/test/java/org/apache/hadoop/ozone/container/common/TestDatanodeStateMachine.java b/hadoop-hdds/container-service/src/test/java/org/apache/hadoop/ozone/container/common/TestDatanodeStateMachine.java index ee82c571a2..ece75459b9 100644 --- a/hadoop-hdds/container-service/src/test/java/org/apache/hadoop/ozone/container/common/TestDatanodeStateMachine.java +++ b/hadoop-hdds/container-service/src/test/java/org/apache/hadoop/ozone/container/common/TestDatanodeStateMachine.java @@ -209,8 +209,10 @@ public void testDatanodeStateContext() throws IOException, conf.get(ScmConfigKeys.OZONE_SCM_DATANODE_ID)); idPath.delete(); DatanodeDetails datanodeDetails = getNewDatanodeDetails(); - datanodeDetails.setContainerPort( + DatanodeDetails.Port port = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, OzoneConfigKeys.DFS_CONTAINER_IPC_PORT_DEFAULT); + datanodeDetails.setPort(port); ContainerUtils.writeDatanodeDetailsTo(datanodeDetails, idPath); try (DatanodeStateMachine stateMachine = @@ -360,13 +362,19 @@ public void testDatanodeStateMachineWithInvalidConfiguration() } private DatanodeDetails getNewDatanodeDetails() { + DatanodeDetails.Port containerPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, 0); + DatanodeDetails.Port ratisPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.RATIS, 0); + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, 0); return DatanodeDetails.newBuilder() .setUuid(UUID.randomUUID().toString()) .setHostName("localhost") .setIpAddress("127.0.0.1") - .setContainerPort(0) - .setRatisPort(0) - .setOzoneRestPort(0) + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort) .build(); } } diff --git a/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/TestUtils.java b/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/TestUtils.java index b8036d7dee..7568bf313b 100644 --- a/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/TestUtils.java +++ b/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/TestUtils.java @@ -124,13 +124,19 @@ private static DatanodeDetails getDatanodeDetails(String uuid) { .nextInt(256) + "." + random.nextInt(256); String hostName = uuid; + DatanodeDetails.Port containerPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, 0); + DatanodeDetails.Port ratisPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.RATIS, 0); + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, 0); DatanodeDetails.Builder builder = DatanodeDetails.newBuilder(); builder.setUuid(uuid) .setHostName("localhost") .setIpAddress(ipAddress) - .setContainerPort(0) - .setRatisPort(0) - .setOzoneRestPort(0); + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort); return builder.build(); } diff --git a/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/block/TestDeletedBlockLog.java b/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/block/TestDeletedBlockLog.java index 8c12806e8c..adb212a409 100644 --- a/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/block/TestDeletedBlockLog.java +++ b/hadoop-hdds/server-scm/src/test/java/org/apache/hadoop/hdds/scm/block/TestDeletedBlockLog.java @@ -265,21 +265,27 @@ public void testDeletedBlockTransactions() throws IOException { int count = 0; long containerID = 0L; + DatanodeDetails.Port containerPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, 0); + DatanodeDetails.Port ratisPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.RATIS, 0); + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, 0); DatanodeDetails dnId1 = DatanodeDetails.newBuilder() .setUuid(UUID.randomUUID().toString()) .setIpAddress("127.0.0.1") .setHostName("localhost") - .setContainerPort(0) - .setRatisPort(0) - .setOzoneRestPort(0) + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort) .build(); DatanodeDetails dnId2 = DatanodeDetails.newBuilder() .setUuid(UUID.randomUUID().toString()) .setIpAddress("127.0.0.1") .setHostName("localhost") - .setContainerPort(0) - .setRatisPort(0) - .setOzoneRestPort(0) + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort) .build(); Mapping mappingService = mock(ContainerMapping.class); // Creates {TXNum} TX in the log. diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/MiniOzoneClusterImpl.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/MiniOzoneClusterImpl.java index ad8b0163b4..f0bfef17be 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/MiniOzoneClusterImpl.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/MiniOzoneClusterImpl.java @@ -24,6 +24,7 @@ import org.apache.commons.io.FileUtils; import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.conf.Configuration; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.hdfs.DFSConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; import org.apache.hadoop.ipc.Client; @@ -219,13 +220,15 @@ public void restartHddsDatanode(int i) { datanodeService.stop(); datanodeService.join(); // ensure same ports are used across restarts. - Configuration config = datanodeService.getConf(); - int currentPort = datanodeService.getDatanodeDetails().getContainerPort(); - config.setInt(DFS_CONTAINER_IPC_PORT, currentPort); - config.setBoolean(DFS_CONTAINER_IPC_RANDOM_PORT, false); - int ratisPort = datanodeService.getDatanodeDetails().getRatisPort(); - config.setInt(DFS_CONTAINER_RATIS_IPC_PORT, ratisPort); - config.setBoolean(DFS_CONTAINER_RATIS_IPC_RANDOM_PORT, false); + Configuration conf = datanodeService.getConf(); + int currentPort = datanodeService.getDatanodeDetails() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue(); + conf.setInt(DFS_CONTAINER_IPC_PORT, currentPort); + conf.setBoolean(DFS_CONTAINER_IPC_RANDOM_PORT, false); + int ratisPort = datanodeService.getDatanodeDetails() + .getPort(DatanodeDetails.Port.Name.RATIS).getValue(); + conf.setInt(DFS_CONTAINER_RATIS_IPC_PORT, ratisPort); + conf.setBoolean(DFS_CONTAINER_RATIS_IPC_RANDOM_PORT, false); datanodeService.start(null); } diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/RatisTestHelper.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/RatisTestHelper.java index 1a35c5008c..fce9e77947 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/RatisTestHelper.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/RatisTestHelper.java @@ -22,6 +22,7 @@ import org.apache.hadoop.hdds.conf.OzoneConfiguration; import org.apache.hadoop.ozone.client.protocol.ClientProtocol; import org.apache.hadoop.ozone.client.rpc.RpcClient; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.container.ContainerTestHelper; import org.apache.hadoop.ozone.client.rest.OzoneException; import org.apache.ratis.rpc.RpcType; @@ -78,7 +79,7 @@ public void close() { public int getDatanodeOzoneRestPort() { return cluster.getHddsDatanodes().get(0).getDatanodeDetails() - .getOzoneRestPort(); + .getPort(DatanodeDetails.Port.Name.REST).getValue(); } } diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/TestMiniOzoneCluster.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/TestMiniOzoneCluster.java index 29238cf536..0254984d23 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/TestMiniOzoneCluster.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/TestMiniOzoneCluster.java @@ -27,7 +27,6 @@ import org.apache.hadoop.ozone.container.ozoneimpl.TestOzoneContainer; import org.apache.hadoop.hdds.protocol.proto.HddsProtos; import org.apache.hadoop.hdds.scm.TestUtils; -import org.apache.hadoop.ozone.web.utils.OzoneUtils; import org.apache.hadoop.hdds.scm.XceiverClient; import org.apache.hadoop.hdds.scm.container.common.helpers.PipelineChannel; import org.apache.hadoop.hdds.scm.container.common.helpers.Pipeline; @@ -44,6 +43,7 @@ import java.util.HashSet; import java.util.List; +import static org.apache.hadoop.hdds.protocol.DatanodeDetails.Port; import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_DATANODE_DATA_DIR_KEY; import static org.apache.hadoop.ozone.OzoneConfigKeys.DFS_CONTAINER_RATIS_IPC_RANDOM_PORT; import static org.apache.hadoop.ozone.OzoneConfigKeys.OZONE_METADATA_DIRS; @@ -114,9 +114,9 @@ public void testDatanodeIDPersistent() throws Exception { DatanodeDetails id1 = TestUtils.getDatanodeDetails(); DatanodeDetails id2 = TestUtils.getDatanodeDetails(); DatanodeDetails id3 = TestUtils.getDatanodeDetails(); - id1.setContainerPort(1); - id2.setContainerPort(2); - id3.setContainerPort(3); + id1.setPort(DatanodeDetails.newPort(Port.Name.STANDALONE, 1)); + id2.setPort(DatanodeDetails.newPort(Port.Name.STANDALONE, 2)); + id3.setPort(DatanodeDetails.newPort(Port.Name.STANDALONE, 3)); // Write a single ID to the file and read it out File validIdsFile = new File(WRITE_TMP, "valid-values.id"); diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ContainerTestHelper.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ContainerTestHelper.java index d2a64340dc..7046132f6f 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ContainerTestHelper.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ContainerTestHelper.java @@ -94,13 +94,19 @@ public static String createLocalAddress() throws IOException { public static DatanodeDetails createDatanodeDetails() throws IOException { ServerSocket socket = new ServerSocket(0); int port = socket.getLocalPort(); + DatanodeDetails.Port containerPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, port); + DatanodeDetails.Port ratisPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.RATIS, port); + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, port); DatanodeDetails datanodeDetails = DatanodeDetails.newBuilder() .setUuid(UUID.randomUUID().toString()) .setIpAddress(socket.getInetAddress().getHostAddress()) .setHostName(socket.getInetAddress().getHostName()) - .setContainerPort(port) - .setRatisPort(port) - .setOzoneRestPort(port) + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort) .build(); socket.close(); diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/metrics/TestContainerMetrics.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/metrics/TestContainerMetrics.java index 2921be237f..ccad6f8d60 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/metrics/TestContainerMetrics.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/metrics/TestContainerMetrics.java @@ -65,7 +65,8 @@ public void testContainerMetrics() throws Exception { .createSingleNodePipeline(); OzoneConfiguration conf = new OzoneConfiguration(); conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()); + pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()); conf.setInt(DFSConfigKeys.DFS_METRICS_PERCENTILES_INTERVALS_KEY, interval); diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ozoneimpl/TestOzoneContainer.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ozoneimpl/TestOzoneContainer.java index 513974af4f..67a8160e36 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ozoneimpl/TestOzoneContainer.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/ozoneimpl/TestOzoneContainer.java @@ -19,6 +19,7 @@ package org.apache.hadoop.ozone.container.ozoneimpl; import org.apache.hadoop.hdds.client.BlockID; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.hdds.protocol.datanode.proto.ContainerProtos; import org.apache.hadoop.ozone.MiniOzoneCluster; import org.apache.hadoop.ozone.OzoneConfigKeys; @@ -62,8 +63,8 @@ public void testCreateOzoneContainer() throws Exception { // We don't start Ozone Container via data node, we will do it // independently in our test path. Pipeline pipeline = ContainerTestHelper.createSingleNodePipeline(); - conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()); + conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()); conf.setBoolean(OzoneConfigKeys.DFS_CONTAINER_IPC_RANDOM_PORT, false); container = new OzoneContainer(TestUtils.getDatanodeDetails(), conf); container.start(); @@ -101,7 +102,8 @@ public void testOzoneContainerViaDataNode() throws Exception { Pipeline pipeline = ContainerTestHelper.createSingleNodePipeline(); conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()); + pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()); cluster = MiniOzoneCluster.newBuilder(conf) .setRandomContainerPort(false) @@ -527,7 +529,8 @@ private static XceiverClient createClientForTesting(OzoneConfiguration conf) Pipeline pipeline = ContainerTestHelper.createSingleNodePipeline(); conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()); + pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()); // This client talks to ozone container via datanode. return new XceiverClient(pipeline, conf); diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/server/TestContainerServer.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/server/TestContainerServer.java index eb170eaf04..d4c572f116 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/server/TestContainerServer.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/container/server/TestContainerServer.java @@ -103,7 +103,8 @@ public void testClientServer() throws Exception { DatanodeDetails datanodeDetails = TestUtils.getDatanodeDetails(); runTestClientServer(1, (pipeline, conf) -> conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()), + pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()), XceiverClient::new, (dn, conf) -> new XceiverServer(datanodeDetails, conf, new TestContainerDispatcher()), @@ -130,7 +131,7 @@ public void testClientServerRatisGrpc() throws Exception { static XceiverServerRatis newXceiverServerRatis( DatanodeDetails dn, OzoneConfiguration conf) throws IOException { conf.setInt(OzoneConfigKeys.DFS_CONTAINER_RATIS_IPC_PORT, - dn.getRatisPort()); + dn.getPort(DatanodeDetails.Port.Name.RATIS).getValue()); final String dir = TEST_DIR + dn.getUuid(); conf.set(OzoneConfigKeys.DFS_CONTAINER_RATIS_DATANODE_STORAGE_DIR, dir); @@ -208,7 +209,8 @@ public void testClientServerWithContainerDispatcher() throws Exception { Pipeline pipeline = ContainerTestHelper.createSingleNodePipeline(); OzoneConfiguration conf = new OzoneConfiguration(); conf.setInt(OzoneConfigKeys.DFS_CONTAINER_IPC_PORT, - pipeline.getLeader().getContainerPort()); + pipeline.getLeader() + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue()); Dispatcher dispatcher = new Dispatcher(mock(ContainerManager.class), conf); diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/ksm/TestKeySpaceManagerRestInterface.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/ksm/TestKeySpaceManagerRestInterface.java index 2fb70f9b10..feb83d3e5a 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/ksm/TestKeySpaceManagerRestInterface.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/ksm/TestKeySpaceManagerRestInterface.java @@ -118,8 +118,9 @@ public void testGetServiceList() throws Exception { switch (type) { case HTTP: case HTTPS: - Assert.assertEquals(datanodeDetails.getOzoneRestPort(), - (int) ports.get(type)); + Assert.assertEquals( + datanodeDetails.getPort(DatanodeDetails.Port.Name.REST).getValue(), + ports.get(type)); break; default: // KSM only sends Datanode's info port details diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestDistributedOzoneVolumes.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestDistributedOzoneVolumes.java index 1015ae12c1..0e61391c63 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestDistributedOzoneVolumes.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestDistributedOzoneVolumes.java @@ -17,6 +17,7 @@ */ package org.apache.hadoop.ozone.web; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.MiniOzoneCluster; import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; @@ -67,7 +68,8 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).build(); cluster.waitForClusterToBeReady(); port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); + .getDatanodeDetails() + .getPort(DatanodeDetails.Port.Name.REST).getValue(); } /** diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestLocalOzoneVolumes.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestLocalOzoneVolumes.java index 922587e2c4..441f771e84 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestLocalOzoneVolumes.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestLocalOzoneVolumes.java @@ -17,6 +17,7 @@ */ package org.apache.hadoop.ozone.web; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; import org.apache.hadoop.ozone.TestOzoneHelper; @@ -70,7 +71,8 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).build(); cluster.waitForClusterToBeReady(); port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); + .getDatanodeDetails().getPort( + DatanodeDetails.Port.Name.REST).getValue(); } /** diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestOzoneWebAccess.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestOzoneWebAccess.java index 6c32f071e6..c014a60e63 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestOzoneWebAccess.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/TestOzoneWebAccess.java @@ -18,6 +18,7 @@ package org.apache.hadoop.ozone.web; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.MiniOzoneCluster; import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; @@ -78,7 +79,8 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).build(); cluster.waitForClusterToBeReady(); port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); + .getDatanodeDetails().getPort( + DatanodeDetails.Port.Name.REST).getValue(); } /** diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestOzoneClient.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestOzoneClient.java index 627826e8b1..86de8dff65 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestOzoneClient.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestOzoneClient.java @@ -43,6 +43,7 @@ import io.netty.handler.logging.LogLevel; import io.netty.handler.logging.LoggingHandler; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.MiniOzoneCluster; import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; @@ -96,7 +97,8 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).build(); cluster.waitForClusterToBeReady(); int port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); + .getDatanodeDetails() + .getPort(DatanodeDetails.Port.Name.REST).getValue(); endpoint = String.format("http://localhost:%d", port); } diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolume.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolume.java index f8c7eecb45..a510430252 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolume.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolume.java @@ -81,8 +81,6 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).build(); cluster.waitForClusterToBeReady(); - final int port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); client = new RpcClient(conf); } diff --git a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolumeRatis.java b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolumeRatis.java index bc4ba25aba..dcb4030c24 100644 --- a/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolumeRatis.java +++ b/hadoop-ozone/integration-test/src/test/java/org/apache/hadoop/ozone/web/client/TestVolumeRatis.java @@ -19,6 +19,7 @@ package org.apache.hadoop.ozone.web.client; import org.apache.commons.io.FileUtils; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.ozone.MiniOzoneCluster; import org.apache.hadoop.ozone.OzoneConfigKeys; import org.apache.hadoop.hdds.conf.OzoneConfiguration; @@ -63,7 +64,8 @@ public static void init() throws Exception { cluster = MiniOzoneCluster.newBuilder(conf).setNumDatanodes(3).build(); cluster.waitForClusterToBeReady(); final int port = cluster.getHddsDatanodes().get(0) - .getDatanodeDetails().getOzoneRestPort(); + .getDatanodeDetails() + .getPort(DatanodeDetails.Port.Name.REST).getValue(); client = new RpcClient(conf); } diff --git a/hadoop-ozone/objectstore-service/src/main/java/org/apache/hadoop/ozone/web/OzoneHddsDatanodeService.java b/hadoop-ozone/objectstore-service/src/main/java/org/apache/hadoop/ozone/web/OzoneHddsDatanodeService.java index 2283ba6523..87b1e21309 100644 --- a/hadoop-ozone/objectstore-service/src/main/java/org/apache/hadoop/ozone/web/OzoneHddsDatanodeService.java +++ b/hadoop-ozone/objectstore-service/src/main/java/org/apache/hadoop/ozone/web/OzoneHddsDatanodeService.java @@ -20,6 +20,7 @@ import java.io.IOException; import org.apache.hadoop.conf.Configuration; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.hdfs.server.datanode.ObjectStoreHandler; import org.apache.hadoop.ozone.HddsDatanodeService; import org.apache.hadoop.ozone.web.netty.ObjectStoreRestHttpServer; @@ -51,8 +52,10 @@ public void start(Object service) { objectStoreRestHttpServer = new ObjectStoreRestHttpServer( conf, null, handler); objectStoreRestHttpServer.start(); - hddsDatanodeService.getDatanodeDetails().setOzoneRestPort( + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, objectStoreRestHttpServer.getHttpAddress().getPort()); + hddsDatanodeService.getDatanodeDetails().setPort(restPort); } catch (IOException e) { throw new RuntimeException("Can't start the Object Store Rest server", diff --git a/hadoop-ozone/ozone-manager/src/main/java/org/apache/hadoop/ozone/ksm/KeySpaceManager.java b/hadoop-ozone/ozone-manager/src/main/java/org/apache/hadoop/ozone/ksm/KeySpaceManager.java index d0f0c9b7a7..dc8fc913c6 100644 --- a/hadoop-ozone/ozone-manager/src/main/java/org/apache/hadoop/ozone/ksm/KeySpaceManager.java +++ b/hadoop-ozone/ozone-manager/src/main/java/org/apache/hadoop/ozone/ksm/KeySpaceManager.java @@ -21,6 +21,7 @@ import com.google.common.base.Preconditions; import com.google.protobuf.BlockingService; import org.apache.hadoop.classification.InterfaceAudience; +import org.apache.hadoop.hdds.protocol.DatanodeDetails; import org.apache.hadoop.hdfs.DFSUtil; import org.apache.hadoop.ipc.Client; import org.apache.hadoop.ipc.ProtobufRpcEngine; @@ -896,7 +897,8 @@ public List getServiceList() throws IOException { dnServiceInfoBuilder.addServicePort(ServicePort.newBuilder() .setType(ServicePort.Type.HTTP) - .setValue(datanode.getOzoneRestPort()) + .setValue(DatanodeDetails.getFromProtoBuf(datanode) + .getPort(DatanodeDetails.Port.Name.REST).getValue()) .build()); services.add(dnServiceInfoBuilder.build()); diff --git a/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/genesis/GenesisUtil.java b/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/genesis/GenesisUtil.java index 611b62dfb0..7f864ae6bf 100644 --- a/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/genesis/GenesisUtil.java +++ b/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/genesis/GenesisUtil.java @@ -78,13 +78,19 @@ public static DatanodeDetails createDatanodeDetails(String uuid) { random.nextInt(256) + "." + random.nextInt(256) + "." + random .nextInt(256) + "." + random.nextInt(256); + DatanodeDetails.Port containerPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.STANDALONE, 0); + DatanodeDetails.Port ratisPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.RATIS, 0); + DatanodeDetails.Port restPort = DatanodeDetails.newPort( + DatanodeDetails.Port.Name.REST, 0); DatanodeDetails.Builder builder = DatanodeDetails.newBuilder(); builder.setUuid(uuid) .setHostName("localhost") .setIpAddress(ipAddress) - .setContainerPort(0) - .setRatisPort(0) - .setOzoneRestPort(0); + .addPort(containerPort) + .addPort(ratisPort) + .addPort(restPort); return builder.build(); } } diff --git a/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/scm/cli/SQLCLI.java b/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/scm/cli/SQLCLI.java index 028b1fc2a3..d4ac994cff 100644 --- a/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/scm/cli/SQLCLI.java +++ b/hadoop-ozone/tools/src/main/java/org/apache/hadoop/ozone/scm/cli/SQLCLI.java @@ -530,7 +530,8 @@ private void insertContainerDB(Connection conn, long containerID, // but this seems a bit cleaner. String ipAddr = dd.getIpAddress(); String hostName = dd.getHostName(); - int containerPort = dd.getContainerPort(); + int containerPort = DatanodeDetails.getFromProtoBuf(dd) + .getPort(DatanodeDetails.Port.Name.STANDALONE).getValue(); String insertMachineInfo = String.format( INSERT_DATANODE_INFO, hostName, uuid, ipAddr, containerPort); executeSQL(conn, insertMachineInfo); @@ -598,7 +599,8 @@ private void insertNodePoolDB(Connection conn, String blockPool, String insertDatanodeDetails = String .format(INSERT_DATANODE_INFO, datanodeDetails.getHostName(), datanodeDetails.getUuidString(), datanodeDetails.getIpAddress(), - datanodeDetails.getContainerPort()); + datanodeDetails.getPort(DatanodeDetails.Port.Name.STANDALONE) + .getValue()); executeSQL(conn, insertDatanodeDetails); } diff --git a/hadoop-tools/hadoop-ozone/src/test/java/org/apache/hadoop/fs/ozone/TestOzoneFSInputStream.java b/hadoop-tools/hadoop-ozone/src/test/java/org/apache/hadoop/fs/ozone/TestOzoneFSInputStream.java index 4d8c9d6162..b82c4a135d 100644 --- a/hadoop-tools/hadoop-ozone/src/test/java/org/apache/hadoop/fs/ozone/TestOzoneFSInputStream.java +++ b/hadoop-tools/hadoop-ozone/src/test/java/org/apache/hadoop/fs/ozone/TestOzoneFSInputStream.java @@ -90,7 +90,8 @@ public static void init() throws Exception { // Fetch the host and port for File System init DatanodeDetails datanodeDetails = cluster.getHddsDatanodes().get(0) .getDatanodeDetails(); - int port = datanodeDetails.getOzoneRestPort(); + int port = datanodeDetails + .getPort(DatanodeDetails.Port.Name.REST).getValue(); String host = datanodeDetails.getHostName(); // Set the fs.defaultFS and start the filesystem