HDFS-13852. RBF: The DN_REPORT_TIME_OUT and DN_REPORT_CACHE_EXPIRE should be configured in RBFConfigKeys. Contributed by yanghuafeng.
This commit is contained in:
parent
ebfd2d8a4e
commit
04caaba488
@ -47,12 +47,14 @@ import javax.management.NotCompliantMBeanException;
|
|||||||
import javax.management.ObjectName;
|
import javax.management.ObjectName;
|
||||||
import javax.management.StandardMBean;
|
import javax.management.StandardMBean;
|
||||||
|
|
||||||
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
|
import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
|
||||||
import org.apache.hadoop.hdfs.protocol.HdfsConstants.DatanodeReportType;
|
import org.apache.hadoop.hdfs.protocol.HdfsConstants.DatanodeReportType;
|
||||||
import org.apache.hadoop.hdfs.server.federation.resolver.ActiveNamenodeResolver;
|
import org.apache.hadoop.hdfs.server.federation.resolver.ActiveNamenodeResolver;
|
||||||
import org.apache.hadoop.hdfs.server.federation.resolver.FederationNamenodeContext;
|
import org.apache.hadoop.hdfs.server.federation.resolver.FederationNamenodeContext;
|
||||||
import org.apache.hadoop.hdfs.server.federation.resolver.FederationNamespaceInfo;
|
import org.apache.hadoop.hdfs.server.federation.resolver.FederationNamespaceInfo;
|
||||||
import org.apache.hadoop.hdfs.server.federation.resolver.RemoteLocation;
|
import org.apache.hadoop.hdfs.server.federation.resolver.RemoteLocation;
|
||||||
|
import org.apache.hadoop.hdfs.server.federation.router.RBFConfigKeys;
|
||||||
import org.apache.hadoop.hdfs.server.federation.router.Router;
|
import org.apache.hadoop.hdfs.server.federation.router.Router;
|
||||||
import org.apache.hadoop.hdfs.server.federation.router.RouterRpcServer;
|
import org.apache.hadoop.hdfs.server.federation.router.RouterRpcServer;
|
||||||
import org.apache.hadoop.hdfs.server.federation.store.MembershipStore;
|
import org.apache.hadoop.hdfs.server.federation.store.MembershipStore;
|
||||||
@ -95,7 +97,7 @@ public class FederationMetrics implements FederationMBean {
|
|||||||
private static final String DATE_FORMAT = "yyyy/MM/dd HH:mm:ss";
|
private static final String DATE_FORMAT = "yyyy/MM/dd HH:mm:ss";
|
||||||
|
|
||||||
/** Prevent holding the page from load too long. */
|
/** Prevent holding the page from load too long. */
|
||||||
private static final long TIME_OUT = TimeUnit.SECONDS.toMillis(1);
|
private final long timeOut;
|
||||||
|
|
||||||
|
|
||||||
/** Router interface. */
|
/** Router interface. */
|
||||||
@ -143,6 +145,12 @@ public class FederationMetrics implements FederationMBean {
|
|||||||
this.routerStore = stateStore.getRegisteredRecordStore(
|
this.routerStore = stateStore.getRegisteredRecordStore(
|
||||||
RouterStore.class);
|
RouterStore.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Initialize the cache for the DN reports
|
||||||
|
Configuration conf = router.getConfig();
|
||||||
|
this.timeOut = conf.getTimeDuration(RBFConfigKeys.DN_REPORT_TIME_OUT,
|
||||||
|
RBFConfigKeys.DN_REPORT_TIME_OUT_MS_DEFAULT, TimeUnit.MILLISECONDS);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -434,7 +442,7 @@ public class FederationMetrics implements FederationMBean {
|
|||||||
try {
|
try {
|
||||||
RouterRpcServer rpcServer = this.router.getRpcServer();
|
RouterRpcServer rpcServer = this.router.getRpcServer();
|
||||||
DatanodeInfo[] live = rpcServer.getDatanodeReport(
|
DatanodeInfo[] live = rpcServer.getDatanodeReport(
|
||||||
DatanodeReportType.LIVE, false, TIME_OUT);
|
DatanodeReportType.LIVE, false, timeOut);
|
||||||
|
|
||||||
if (live.length > 0) {
|
if (live.length > 0) {
|
||||||
float totalDfsUsed = 0;
|
float totalDfsUsed = 0;
|
||||||
|
@ -74,21 +74,6 @@ public class NamenodeBeanMetrics
|
|||||||
private static final Logger LOG =
|
private static final Logger LOG =
|
||||||
LoggerFactory.getLogger(NamenodeBeanMetrics.class);
|
LoggerFactory.getLogger(NamenodeBeanMetrics.class);
|
||||||
|
|
||||||
/** Prevent holding the page from loading too long. */
|
|
||||||
private static final String DN_REPORT_TIME_OUT =
|
|
||||||
RBFConfigKeys.FEDERATION_ROUTER_PREFIX + "dn-report.time-out";
|
|
||||||
/** We only wait for 1 second. */
|
|
||||||
private static final long DN_REPORT_TIME_OUT_DEFAULT =
|
|
||||||
TimeUnit.SECONDS.toMillis(1);
|
|
||||||
|
|
||||||
/** Time to cache the DN information. */
|
|
||||||
public static final String DN_REPORT_CACHE_EXPIRE =
|
|
||||||
RBFConfigKeys.FEDERATION_ROUTER_PREFIX + "dn-report.cache-expire";
|
|
||||||
/** We cache the DN information for 10 seconds by default. */
|
|
||||||
public static final long DN_REPORT_CACHE_EXPIRE_DEFAULT =
|
|
||||||
TimeUnit.SECONDS.toMillis(10);
|
|
||||||
|
|
||||||
|
|
||||||
/** Instance of the Router being monitored. */
|
/** Instance of the Router being monitored. */
|
||||||
private final Router router;
|
private final Router router;
|
||||||
|
|
||||||
@ -148,10 +133,11 @@ public class NamenodeBeanMetrics
|
|||||||
// Initialize the cache for the DN reports
|
// Initialize the cache for the DN reports
|
||||||
Configuration conf = router.getConfig();
|
Configuration conf = router.getConfig();
|
||||||
this.dnReportTimeOut = conf.getTimeDuration(
|
this.dnReportTimeOut = conf.getTimeDuration(
|
||||||
DN_REPORT_TIME_OUT, DN_REPORT_TIME_OUT_DEFAULT, TimeUnit.MILLISECONDS);
|
RBFConfigKeys.DN_REPORT_TIME_OUT,
|
||||||
|
RBFConfigKeys.DN_REPORT_TIME_OUT_MS_DEFAULT, TimeUnit.MILLISECONDS);
|
||||||
long dnCacheExpire = conf.getTimeDuration(
|
long dnCacheExpire = conf.getTimeDuration(
|
||||||
DN_REPORT_CACHE_EXPIRE,
|
RBFConfigKeys.DN_REPORT_CACHE_EXPIRE,
|
||||||
DN_REPORT_CACHE_EXPIRE_DEFAULT, TimeUnit.MILLISECONDS);
|
RBFConfigKeys.DN_REPORT_CACHE_EXPIRE_MS_DEFAULT, TimeUnit.MILLISECONDS);
|
||||||
this.dnCache = CacheBuilder.newBuilder()
|
this.dnCache = CacheBuilder.newBuilder()
|
||||||
.expireAfterWrite(dnCacheExpire, TimeUnit.MILLISECONDS)
|
.expireAfterWrite(dnCacheExpire, TimeUnit.MILLISECONDS)
|
||||||
.build(
|
.build(
|
||||||
|
@ -233,6 +233,13 @@ public class RBFConfigKeys extends CommonConfigurationKeysPublic {
|
|||||||
FEDERATION_ROUTER_PREFIX + "https-bind-host";
|
FEDERATION_ROUTER_PREFIX + "https-bind-host";
|
||||||
public static final String DFS_ROUTER_HTTPS_ADDRESS_DEFAULT =
|
public static final String DFS_ROUTER_HTTPS_ADDRESS_DEFAULT =
|
||||||
"0.0.0.0:" + DFS_ROUTER_HTTPS_PORT_DEFAULT;
|
"0.0.0.0:" + DFS_ROUTER_HTTPS_PORT_DEFAULT;
|
||||||
|
public static final String DN_REPORT_TIME_OUT =
|
||||||
|
FEDERATION_ROUTER_PREFIX + "dn-report.time-out";
|
||||||
|
public static final long DN_REPORT_TIME_OUT_MS_DEFAULT = 1000;
|
||||||
|
public static final String DN_REPORT_CACHE_EXPIRE =
|
||||||
|
FEDERATION_ROUTER_PREFIX + "dn-report.cache-expire";
|
||||||
|
public static final long DN_REPORT_CACHE_EXPIRE_MS_DEFAULT =
|
||||||
|
TimeUnit.SECONDS.toMillis(10);
|
||||||
|
|
||||||
// HDFS Router-based federation quota
|
// HDFS Router-based federation quota
|
||||||
public static final String DFS_ROUTER_QUOTA_ENABLE =
|
public static final String DFS_ROUTER_QUOTA_ENABLE =
|
||||||
|
@ -143,6 +143,23 @@
|
|||||||
</description>
|
</description>
|
||||||
</property>
|
</property>
|
||||||
|
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>dfs.federation.router.dn-report.time-out</name>
|
||||||
|
<value>1000</value>
|
||||||
|
<description>
|
||||||
|
Time out, in milliseconds for getDatanodeReport.
|
||||||
|
</description>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>dfs.federation.router.dn-report.cache-expire</name>
|
||||||
|
<value>10s</value>
|
||||||
|
<description>
|
||||||
|
Expiration time in seconds for datanodereport.
|
||||||
|
</description>
|
||||||
|
</property>
|
||||||
|
|
||||||
<property>
|
<property>
|
||||||
<name>dfs.federation.router.metrics.class</name>
|
<name>dfs.federation.router.metrics.class</name>
|
||||||
<value>org.apache.hadoop.hdfs.server.federation.metrics.FederationRPCPerformanceMonitor</value>
|
<value>org.apache.hadoop.hdfs.server.federation.metrics.FederationRPCPerformanceMonitor</value>
|
||||||
|
@ -81,7 +81,7 @@ public class TestRouterRPCClientRetries {
|
|||||||
.rpc()
|
.rpc()
|
||||||
.build();
|
.build();
|
||||||
routerConf.setTimeDuration(
|
routerConf.setTimeDuration(
|
||||||
NamenodeBeanMetrics.DN_REPORT_CACHE_EXPIRE, 1, TimeUnit.SECONDS);
|
RBFConfigKeys.DN_REPORT_CACHE_EXPIRE, 1, TimeUnit.SECONDS);
|
||||||
|
|
||||||
// reduce IPC client connection retry times and interval time
|
// reduce IPC client connection retry times and interval time
|
||||||
Configuration clientConf = new Configuration(false);
|
Configuration clientConf = new Configuration(false);
|
||||||
|
@ -175,7 +175,7 @@ public class TestRouterRpc {
|
|||||||
.build();
|
.build();
|
||||||
// We decrease the DN cache times to make the test faster
|
// We decrease the DN cache times to make the test faster
|
||||||
routerConf.setTimeDuration(
|
routerConf.setTimeDuration(
|
||||||
NamenodeBeanMetrics.DN_REPORT_CACHE_EXPIRE, 1, TimeUnit.SECONDS);
|
RBFConfigKeys.DN_REPORT_CACHE_EXPIRE, 1, TimeUnit.SECONDS);
|
||||||
cluster.addRouterOverrides(routerConf);
|
cluster.addRouterOverrides(routerConf);
|
||||||
cluster.startRouters();
|
cluster.startRouters();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user