HDFS-14460. DFSUtil#getNamenodeWebAddr should return HTTPS address based on policy configured. Contributed by CR Hota.
(cherry picked from commit 865c328930
)
This commit is contained in:
parent
5436df0c94
commit
528dc8199b
|
@ -1307,11 +1307,15 @@ public class DFSUtil {
|
|||
nsId = getOnlyNameServiceIdOrNull(conf);
|
||||
}
|
||||
|
||||
String webAddrBaseKey = DFSConfigKeys.DFS_NAMENODE_HTTP_ADDRESS_KEY;
|
||||
String webAddrDefault = DFSConfigKeys.DFS_NAMENODE_HTTP_ADDRESS_DEFAULT;
|
||||
if (getHttpPolicy(conf) == HttpConfig.Policy.HTTPS_ONLY) {
|
||||
webAddrBaseKey = DFSConfigKeys.DFS_NAMENODE_HTTPS_ADDRESS_KEY;
|
||||
webAddrDefault = DFSConfigKeys.DFS_NAMENODE_HTTPS_ADDRESS_DEFAULT;
|
||||
}
|
||||
String webAddrKey = DFSUtilClient.concatSuffixes(
|
||||
DFSConfigKeys.DFS_NAMENODE_HTTP_ADDRESS_KEY, nsId, nnId);
|
||||
|
||||
String webAddr =
|
||||
conf.get(webAddrKey, DFSConfigKeys.DFS_NAMENODE_HTTP_ADDRESS_DEFAULT);
|
||||
webAddrBaseKey, nsId, nnId);
|
||||
String webAddr = conf.get(webAddrKey, webAddrDefault);
|
||||
return webAddr;
|
||||
}
|
||||
|
||||
|
|
|
@ -22,6 +22,8 @@ import static org.apache.hadoop.fs.CommonConfigurationKeysPublic.FS_DEFAULT_NAME
|
|||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_HA_NAMENODES_KEY_PREFIX;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_INTERNAL_NAMESERVICES_KEY;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_BACKUP_ADDRESS_KEY;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_HTTP_POLICY_KEY;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_HTTPS_ADDRESS_KEY;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_HTTPS_PORT_DEFAULT;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_HTTP_ADDRESS_KEY;
|
||||
import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_HTTP_PORT_DEFAULT;
|
||||
|
@ -70,6 +72,7 @@ import org.apache.hadoop.hdfs.protocol.LocatedBlock;
|
|||
import org.apache.hadoop.hdfs.protocol.LocatedBlocks;
|
||||
import org.apache.hadoop.hdfs.server.namenode.NameNode;
|
||||
import org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider;
|
||||
import org.apache.hadoop.http.HttpConfig;
|
||||
import org.apache.hadoop.net.NetUtils;
|
||||
import org.apache.hadoop.security.UserGroupInformation;
|
||||
import org.apache.hadoop.security.alias.CredentialProvider;
|
||||
|
@ -87,6 +90,8 @@ public class TestDFSUtil {
|
|||
static final String NS1_NN_ADDR = "ns1-nn.example.com:8020";
|
||||
static final String NS1_NN1_ADDR = "ns1-nn1.example.com:8020";
|
||||
static final String NS1_NN2_ADDR = "ns1-nn2.example.com:8020";
|
||||
static final String NS1_NN1_HTTPS_ADDR = "ns1-nn1.example.com:50740";
|
||||
static final String NS1_NN1_HTTP_ADDR = "ns1-nn1.example.com:50070";
|
||||
|
||||
/**
|
||||
* Reset to default UGI settings since some tests change them.
|
||||
|
@ -465,6 +470,32 @@ public class TestDFSUtil {
|
|||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testGetNamenodeWebAddr() {
|
||||
HdfsConfiguration conf = new HdfsConfiguration();
|
||||
|
||||
conf.set(DFSUtil.addKeySuffixes(
|
||||
DFS_NAMENODE_HTTPS_ADDRESS_KEY, "ns1", "nn1"), NS1_NN1_HTTPS_ADDR);
|
||||
conf.set(DFSUtil.addKeySuffixes(
|
||||
DFS_NAMENODE_HTTP_ADDRESS_KEY, "ns1", "nn1"), NS1_NN1_HTTP_ADDR);
|
||||
|
||||
conf.set(DFS_HTTP_POLICY_KEY, HttpConfig.Policy.HTTPS_ONLY.name());
|
||||
String httpsOnlyWebAddr = DFSUtil.getNamenodeWebAddr(
|
||||
conf, "ns1", "nn1");
|
||||
assertEquals(NS1_NN1_HTTPS_ADDR, httpsOnlyWebAddr);
|
||||
|
||||
conf.set(DFS_HTTP_POLICY_KEY, HttpConfig.Policy.HTTP_ONLY.name());
|
||||
String httpOnlyWebAddr = DFSUtil.getNamenodeWebAddr(
|
||||
conf, "ns1", "nn1");
|
||||
assertEquals(NS1_NN1_HTTP_ADDR, httpOnlyWebAddr);
|
||||
|
||||
conf.set(DFS_HTTP_POLICY_KEY, HttpConfig.Policy.HTTP_AND_HTTPS.name());
|
||||
String httpAndHttpsWebAddr = DFSUtil.getNamenodeWebAddr(
|
||||
conf, "ns1", "nn1");
|
||||
assertEquals(NS1_NN1_HTTP_ADDR, httpAndHttpsWebAddr);
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testGetInfoServer() throws IOException, URISyntaxException {
|
||||
HdfsConfiguration conf = new HdfsConfiguration();
|
||||
|
|
Loading…
Reference in New Issue