HBASE-1743 [debug tool] Add regionsInTransition list to ClusterStatus detailed output
git-svn-id: https://svn.apache.org/repos/asf/hadoop/hbase/trunk@800676 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
557bd85bc4
commit
b3653a6295
|
@ -546,6 +546,8 @@ Release 0.20.0 - Unreleased
|
||||||
HBASE-1714 Thrift server: prefix scan API
|
HBASE-1714 Thrift server: prefix scan API
|
||||||
HBASE-1719 hold a reference to the region in stores instead of only the
|
HBASE-1719 hold a reference to the region in stores instead of only the
|
||||||
region info
|
region info
|
||||||
|
HBASE-1743 [debug tool] Add regionsInTransition list to ClusterStatus
|
||||||
|
detailed output
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
HBASE-1412 Change values for delete column and column family in KeyValue
|
HBASE-1412 Change values for delete column and column family in KeyValue
|
||||||
|
|
|
@ -270,6 +270,11 @@ module HBase
|
||||||
status = @admin.getClusterStatus()
|
status = @admin.getClusterStatus()
|
||||||
if format != nil and format == "detailed"
|
if format != nil and format == "detailed"
|
||||||
puts("version %s" % [ status.getHBaseVersion() ])
|
puts("version %s" % [ status.getHBaseVersion() ])
|
||||||
|
# Put regions in transition first because usually empty
|
||||||
|
puts("%d regionsInTransition" % status.getRegionsInTransition().size())
|
||||||
|
for k, v in status.getRegionsInTransition()
|
||||||
|
puts(" %s" % [v])
|
||||||
|
end
|
||||||
puts("%d live servers" % [ status.getServers() ])
|
puts("%d live servers" % [ status.getServers() ])
|
||||||
for server in status.getServerInfo()
|
for server in status.getServerInfo()
|
||||||
puts(" %s:%d %d" % \
|
puts(" %s:%d %d" % \
|
||||||
|
|
|
@ -26,6 +26,10 @@ import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.NavigableMap;
|
||||||
|
import java.util.TreeMap;
|
||||||
|
|
||||||
import org.apache.hadoop.io.VersionedWritable;
|
import org.apache.hadoop.io.VersionedWritable;
|
||||||
|
|
||||||
|
@ -41,6 +45,7 @@ import org.apache.hadoop.io.VersionedWritable;
|
||||||
* <li>The number of requests since last report.</li>
|
* <li>The number of requests since last report.</li>
|
||||||
* <li>Detailed region server loading and resource usage information,
|
* <li>Detailed region server loading and resource usage information,
|
||||||
* per server and per region.</li>
|
* per server and per region.</li>
|
||||||
|
* <li>Regions in transition at master</li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
public class ClusterStatus extends VersionedWritable {
|
public class ClusterStatus extends VersionedWritable {
|
||||||
|
@ -49,6 +54,7 @@ public class ClusterStatus extends VersionedWritable {
|
||||||
private String hbaseVersion;
|
private String hbaseVersion;
|
||||||
private Collection<HServerInfo> liveServerInfo;
|
private Collection<HServerInfo> liveServerInfo;
|
||||||
private Collection<String> deadServers;
|
private Collection<String> deadServers;
|
||||||
|
private NavigableMap<String, String> intransition;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor, for Writable
|
* Constructor, for Writable
|
||||||
|
@ -191,6 +197,14 @@ public class ClusterStatus extends VersionedWritable {
|
||||||
this.deadServers = deadServers;
|
this.deadServers = deadServers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<String, String> getRegionsInTransition() {
|
||||||
|
return this.intransition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRegionsInTransition(final NavigableMap<String, String> m) {
|
||||||
|
this.intransition = m;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Writable
|
// Writable
|
||||||
//
|
//
|
||||||
|
@ -206,6 +220,11 @@ public class ClusterStatus extends VersionedWritable {
|
||||||
for (String server: deadServers) {
|
for (String server: deadServers) {
|
||||||
out.writeUTF(server);
|
out.writeUTF(server);
|
||||||
}
|
}
|
||||||
|
out.writeInt(this.intransition.size());
|
||||||
|
for (Map.Entry<String, String> e: this.intransition.entrySet()) {
|
||||||
|
out.writeUTF(e.getKey());
|
||||||
|
out.writeUTF(e.getValue());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void readFields(DataInput in) throws IOException {
|
public void readFields(DataInput in) throws IOException {
|
||||||
|
@ -223,5 +242,12 @@ public class ClusterStatus extends VersionedWritable {
|
||||||
for (int i = 0; i < count; i++) {
|
for (int i = 0; i < count; i++) {
|
||||||
deadServers.add(in.readUTF());
|
deadServers.add(in.readUTF());
|
||||||
}
|
}
|
||||||
|
count = in.readInt();
|
||||||
|
this.intransition = new TreeMap<String, String>();
|
||||||
|
for (int i = 0; i < count; i++) {
|
||||||
|
String key = in.readUTF();
|
||||||
|
String value = in.readUTF();
|
||||||
|
this.intransition.put(key, value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1053,6 +1053,7 @@ public class HMaster extends Thread implements HConstants, HMasterInterface,
|
||||||
status.setHBaseVersion(VersionInfo.getVersion());
|
status.setHBaseVersion(VersionInfo.getVersion());
|
||||||
status.setServerInfo(serverManager.serversToServerInfo.values());
|
status.setServerInfo(serverManager.serversToServerInfo.values());
|
||||||
status.setDeadServers(serverManager.deadServers);
|
status.setDeadServers(serverManager.deadServers);
|
||||||
|
status.setRegionsInTransition(this.regionManager.getRegionsInTransition());
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,21 +20,21 @@
|
||||||
package org.apache.hadoop.hbase.master;
|
package org.apache.hadoop.hbase.master;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.ArrayList;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.Collections;
|
||||||
import java.util.concurrent.locks.Lock;
|
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.SortedMap;
|
import java.util.SortedMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.concurrent.ConcurrentSkipListMap;
|
import java.util.concurrent.ConcurrentSkipListMap;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
import java.util.concurrent.locks.Lock;
|
||||||
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
@ -43,15 +43,15 @@ import org.apache.hadoop.fs.Path;
|
||||||
import org.apache.hadoop.fs.PathFilter;
|
import org.apache.hadoop.fs.PathFilter;
|
||||||
import org.apache.hadoop.hbase.HBaseConfiguration;
|
import org.apache.hadoop.hbase.HBaseConfiguration;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
import org.apache.hadoop.hbase.HMsg;
|
||||||
|
import org.apache.hadoop.hbase.HRegionInfo;
|
||||||
import org.apache.hadoop.hbase.HServerAddress;
|
import org.apache.hadoop.hbase.HServerAddress;
|
||||||
import org.apache.hadoop.hbase.HServerInfo;
|
import org.apache.hadoop.hbase.HServerInfo;
|
||||||
import org.apache.hadoop.hbase.HServerLoad;
|
import org.apache.hadoop.hbase.HServerLoad;
|
||||||
import org.apache.hadoop.hbase.HRegionInfo;
|
|
||||||
import org.apache.hadoop.hbase.RegionHistorian;
|
import org.apache.hadoop.hbase.RegionHistorian;
|
||||||
import org.apache.hadoop.hbase.regionserver.HRegion;
|
|
||||||
import org.apache.hadoop.hbase.client.Put;
|
import org.apache.hadoop.hbase.client.Put;
|
||||||
import org.apache.hadoop.hbase.ipc.HRegionInterface;
|
import org.apache.hadoop.hbase.ipc.HRegionInterface;
|
||||||
import org.apache.hadoop.hbase.HMsg;
|
import org.apache.hadoop.hbase.regionserver.HRegion;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
import org.apache.hadoop.hbase.util.Pair;
|
import org.apache.hadoop.hbase.util.Pair;
|
||||||
import org.apache.hadoop.hbase.util.Threads;
|
import org.apache.hadoop.hbase.util.Threads;
|
||||||
|
@ -1349,24 +1349,19 @@ class RegionManager implements HConstants {
|
||||||
double avg = master.serverManager.getAverageLoad();
|
double avg = master.serverManager.getAverageLoad();
|
||||||
|
|
||||||
// nothing to balance if server load not more then average load
|
// nothing to balance if server load not more then average load
|
||||||
if(servLoad.getLoad() <= Math.ceil(avg) || avg <= 2.0) {
|
if (servLoad.getLoad() <= Math.ceil(avg) || avg <= 2.0) return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if current server is overloaded
|
// check if server is overloaded
|
||||||
int numRegionsToClose = balanceFromOverloaded(servLoad, avg);
|
int numRegionsToClose = balanceFromOverloaded(servLoad, avg);
|
||||||
|
|
||||||
// check if we can unload server by low loaded servers
|
// check if we can unload server by low loaded servers
|
||||||
if(numRegionsToClose <= 0) {
|
if (numRegionsToClose <= 0)
|
||||||
numRegionsToClose = balanceToLowloaded(info.getServerName(), servLoad,
|
balanceToLowloaded(info.getServerName(), servLoad, avg);
|
||||||
avg);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(maxRegToClose > 0) {
|
if (maxRegToClose > 0)
|
||||||
numRegionsToClose = Math.min(numRegionsToClose, maxRegToClose);
|
numRegionsToClose = Math.min(numRegionsToClose, maxRegToClose);
|
||||||
}
|
|
||||||
|
if (numRegionsToClose > 0){
|
||||||
if(numRegionsToClose > 0) {
|
|
||||||
unassignSomeRegions(info, numRegionsToClose, mostLoadedRegions,
|
unassignSomeRegions(info, numRegionsToClose, mostLoadedRegions,
|
||||||
returnMsgs);
|
returnMsgs);
|
||||||
}
|
}
|
||||||
|
@ -1421,13 +1416,26 @@ class RegionManager implements HConstants {
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Server " + srvName + " will be unloaded for " +
|
LOG.debug("Server " + srvName + " will be unloaded for " +
|
||||||
"balance. Server load: " + numSrvRegs + " avg: " +
|
"balance. Server load: " + numSrvRegs + " avg: " +
|
||||||
avgLoad + ", regions can be moved: " + numMoveToLowLoaded +
|
avgLoad + ", regions can be moved: " + numMoveToLowLoaded);
|
||||||
". Regions to close: " + numRegionsToClose);
|
|
||||||
}
|
}
|
||||||
return numRegionsToClose;
|
return numRegionsToClose;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Snapshot of regionsintransition as a sorted Map.
|
||||||
|
*/
|
||||||
|
NavigableMap<String, String> getRegionsInTransition() {
|
||||||
|
NavigableMap<String, String> result = new TreeMap<String, String>();
|
||||||
|
synchronized (this.regionsInTransition) {
|
||||||
|
if (this.regionsInTransition.isEmpty()) return result;
|
||||||
|
for (Map.Entry<String, RegionState> e: this.regionsInTransition.entrySet()) {
|
||||||
|
result.put(e.getKey(), e.getValue().toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* State of a Region as it transitions from closed to open, etc. See
|
* State of a Region as it transitions from closed to open, etc. See
|
||||||
* note on regionsInTransition data member above for listing of state
|
* note on regionsInTransition data member above for listing of state
|
||||||
|
|
Loading…
Reference in New Issue