HBASE-24646 Set the log level for ScheduledChore to INFO in HBTU (#1987)
Signed-off-by: Viraj Jasani <vjasani@apache.org> Signed-off-by: stack <stack@apache.org>
This commit is contained in:
parent
47742b2083
commit
46bf8944fd
|
@ -20,10 +20,10 @@ package org.apache.hadoop.hbase;
|
|||
|
||||
import java.util.concurrent.ScheduledThreadPoolExecutor;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import org.apache.yetus.audience.InterfaceAudience;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;
|
||||
|
||||
/**
|
||||
|
@ -169,11 +169,11 @@ public abstract class ScheduledChore implements Runnable {
|
|||
updateTimeTrackingBeforeRun();
|
||||
if (missedStartTime() && isScheduled()) {
|
||||
onChoreMissedStartTime();
|
||||
if (LOG.isInfoEnabled()) LOG.info("Chore: " + getName() + " missed its start time");
|
||||
LOG.info("Chore: {} missed its start time", getName());
|
||||
} else if (stopper.isStopped() || !isScheduled()) {
|
||||
cancel(false);
|
||||
cleanup();
|
||||
if (LOG.isInfoEnabled()) LOG.info("Chore: " + getName() + " was stopped");
|
||||
LOG.info("Chore: {} was stopped", getName());
|
||||
} else {
|
||||
try {
|
||||
// TODO: Histogram metrics per chore name.
|
||||
|
@ -193,7 +193,7 @@ public abstract class ScheduledChore implements Runnable {
|
|||
TimeUnit.NANOSECONDS.toMillis(end - start));
|
||||
}
|
||||
} catch (Throwable t) {
|
||||
if (LOG.isErrorEnabled()) LOG.error("Caught error", t);
|
||||
LOG.error("Caught error", t);
|
||||
if (this.stopper.isStopped()) {
|
||||
cancel(false);
|
||||
cleanup();
|
||||
|
|
|
@ -599,10 +599,9 @@ public class HBaseTestingUtility extends HBaseZKTestingUtility {
|
|||
EditLogFileOutputStream.setShouldSkipFsyncForTesting(true);
|
||||
|
||||
// Error level to skip some warnings specific to the minicluster. See HBASE-4709
|
||||
org.apache.log4j.Logger.getLogger(org.apache.hadoop.metrics2.util.MBeans.class).
|
||||
setLevel(org.apache.log4j.Level.ERROR);
|
||||
org.apache.log4j.Logger.getLogger(org.apache.hadoop.metrics2.impl.MetricsSystemImpl.class).
|
||||
setLevel(org.apache.log4j.Level.ERROR);
|
||||
Log4jUtils.setLogLevel(org.apache.hadoop.metrics2.util.MBeans.class.getName(), "ERROR");
|
||||
Log4jUtils.setLogLevel(org.apache.hadoop.metrics2.impl.MetricsSystemImpl.class.getName(),
|
||||
"ERROR");
|
||||
|
||||
TraceUtil.initTracer(conf);
|
||||
|
||||
|
@ -626,6 +625,10 @@ public class HBaseTestingUtility extends HBaseZKTestingUtility {
|
|||
|
||||
public MiniDFSCluster startMiniDFSClusterForTestWAL(int namenodePort) throws IOException {
|
||||
createDirsAndSetProperties();
|
||||
// Error level to skip some warnings specific to the minicluster. See HBASE-4709
|
||||
Log4jUtils.setLogLevel(org.apache.hadoop.metrics2.util.MBeans.class.getName(), "ERROR");
|
||||
Log4jUtils.setLogLevel(org.apache.hadoop.metrics2.impl.MetricsSystemImpl.class.getName(),
|
||||
"ERROR");
|
||||
dfsCluster = new MiniDFSCluster(namenodePort, conf, 5, false, true, true, null,
|
||||
null, null, null);
|
||||
return dfsCluster;
|
||||
|
@ -1079,16 +1082,15 @@ public class HBaseTestingUtility extends HBaseZKTestingUtility {
|
|||
}
|
||||
|
||||
/**
|
||||
* Starts up mini hbase cluster.
|
||||
* Usually you won't want this. You'll usually want {@link #startMiniCluster()}.
|
||||
* This is useful when doing stepped startup of clusters.
|
||||
* Starts up mini hbase cluster. Usually you won't want this. You'll usually want
|
||||
* {@link #startMiniCluster()}. This is useful when doing stepped startup of clusters.
|
||||
* @return Reference to the hbase mini hbase cluster.
|
||||
* @see #startMiniCluster(StartMiniClusterOption)
|
||||
* @see #shutdownMiniHBaseCluster()
|
||||
*/
|
||||
public MiniHBaseCluster startMiniHBaseCluster(StartMiniClusterOption option)
|
||||
throws IOException, InterruptedException {
|
||||
// Now do the mini hbase cluster. Set the hbase.rootdir in config.
|
||||
throws IOException, InterruptedException {
|
||||
// Now do the mini hbase cluster. Set the hbase.rootdir in config.
|
||||
createRootDir(option.isCreateRootDir());
|
||||
if (option.isCreateWALDir()) {
|
||||
createWALRootDir();
|
||||
|
@ -1106,22 +1108,26 @@ public class HBaseTestingUtility extends HBaseZKTestingUtility {
|
|||
conf.setInt(ServerManager.WAIT_ON_REGIONSERVERS_MAXTOSTART, option.getNumRegionServers());
|
||||
}
|
||||
|
||||
// Avoid log flooded with chore execution time, see HBASE-24646 for more details.
|
||||
Log4jUtils.setLogLevel(org.apache.hadoop.hbase.ScheduledChore.class.getName(), "INFO");
|
||||
|
||||
Configuration c = new Configuration(this.conf);
|
||||
TraceUtil.initTracer(c);
|
||||
this.hbaseCluster =
|
||||
new MiniHBaseCluster(c, option.getNumMasters(), option.getNumAlwaysStandByMasters(),
|
||||
option.getNumRegionServers(), option.getRsPorts(), option.getMasterClass(),
|
||||
option.getRsClass());
|
||||
this.hbaseCluster = new MiniHBaseCluster(c, option.getNumMasters(),
|
||||
option.getNumAlwaysStandByMasters(), option.getNumRegionServers(), option.getRsPorts(),
|
||||
option.getMasterClass(), option.getRsClass());
|
||||
// Populate the master address configuration from mini cluster configuration.
|
||||
conf.set(HConstants.MASTER_ADDRS_KEY, MasterRegistry.getMasterAddr(c));
|
||||
// Don't leave here till we've done a successful scan of the hbase:meta
|
||||
Table t = getConnection().getTable(TableName.META_TABLE_NAME);
|
||||
ResultScanner s = t.getScanner(new Scan());
|
||||
while (s.next() != null) {
|
||||
continue;
|
||||
try (Table t = getConnection().getTable(TableName.META_TABLE_NAME);
|
||||
ResultScanner s = t.getScanner(new Scan())) {
|
||||
for (;;) {
|
||||
if (s.next() == null) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
s.close();
|
||||
t.close();
|
||||
|
||||
|
||||
getAdmin(); // create immediately the hbaseAdmin
|
||||
LOG.info("Minicluster is up; activeMaster={}", getHBaseCluster().getMaster());
|
||||
|
|
Loading…
Reference in New Issue