HBASE-8172 Fix ./bin/*.rb scripts or remove them
git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1461163 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
56fd88fff6
commit
fbf0b65205
|
@ -34,7 +34,7 @@ zk = ZooKeeperWatcher.new(config, 'get-active-master', nil)
|
||||||
begin
|
begin
|
||||||
master_address = ZKUtil.getData(zk, zk.masterAddressZNode)
|
master_address = ZKUtil.getData(zk, zk.masterAddressZNode)
|
||||||
if master_address
|
if master_address
|
||||||
puts ServerName.parseVersionedServerName(master_address).getHostname()
|
puts ServerName.parseFrom(master_address).getHostname()
|
||||||
else
|
else
|
||||||
puts 'Master not running'
|
puts 'Master not running'
|
||||||
end
|
end
|
||||||
|
|
|
@ -32,25 +32,18 @@ import org.apache.hadoop.hbase.client.Scan
|
||||||
import org.apache.hadoop.hbase.client.HTable
|
import org.apache.hadoop.hbase.client.HTable
|
||||||
import org.apache.hadoop.hbase.client.HConnectionManager
|
import org.apache.hadoop.hbase.client.HConnectionManager
|
||||||
import org.apache.hadoop.hbase.filter.FirstKeyOnlyFilter;
|
import org.apache.hadoop.hbase.filter.FirstKeyOnlyFilter;
|
||||||
import org.apache.hadoop.hbase.HServerAddress
|
|
||||||
import org.apache.hadoop.hbase.util.Bytes
|
import org.apache.hadoop.hbase.util.Bytes
|
||||||
import org.apache.hadoop.hbase.util.Writables
|
import org.apache.hadoop.hbase.util.Writables
|
||||||
import org.apache.hadoop.conf.Configuration
|
import org.apache.hadoop.conf.Configuration
|
||||||
import org.apache.commons.logging.Log
|
import org.apache.commons.logging.Log
|
||||||
import org.apache.commons.logging.LogFactory
|
import org.apache.commons.logging.LogFactory
|
||||||
|
import org.apache.hadoop.hbase.protobuf.ProtobufUtil
|
||||||
|
import org.apache.hadoop.hbase.ServerName
|
||||||
|
import org.apache.hadoop.hbase.HRegionInfo
|
||||||
|
|
||||||
# Name of this script
|
# Name of this script
|
||||||
NAME = "region_mover"
|
NAME = "region_mover"
|
||||||
|
|
||||||
# Get root table reference
|
|
||||||
def getRootTable(config)
|
|
||||||
# Keep meta reference in ruby global
|
|
||||||
if not $ROOT
|
|
||||||
$ROOT = HTable.new(config, HConstants::ROOT_TABLE_NAME)
|
|
||||||
end
|
|
||||||
return $ROOT
|
|
||||||
end
|
|
||||||
|
|
||||||
# Get meta table reference
|
# Get meta table reference
|
||||||
def getMetaTable(config)
|
def getMetaTable(config)
|
||||||
# Keep meta reference in ruby global
|
# Keep meta reference in ruby global
|
||||||
|
@ -93,24 +86,20 @@ end
|
||||||
# Get servername that is up in .META.; this is hostname + port + startcode comma-delimited.
|
# Get servername that is up in .META.; this is hostname + port + startcode comma-delimited.
|
||||||
# Can return nil
|
# Can return nil
|
||||||
def getServerNameForRegion(admin, r)
|
def getServerNameForRegion(admin, r)
|
||||||
if r.isRootRegion()
|
if r.isMetaRegion()
|
||||||
# Hack
|
# Hack
|
||||||
tracker = org.apache.hadoop.hbase.zookeeper.RootRegionTracker.new(admin.getConnection().getZooKeeperWatcher(), RubyAbortable.new())
|
tracker = org.apache.hadoop.hbase.zookeeper.MetaRegionTracker.new(admin.getConnection().getZooKeeperWatcher(), RubyAbortable.new())
|
||||||
tracker.start()
|
tracker.start()
|
||||||
while not tracker.isLocationAvailable()
|
while not tracker.isLocationAvailable()
|
||||||
sleep 0.1
|
sleep 0.1
|
||||||
end
|
end
|
||||||
# Make a fake servername by appending ','
|
# Make a fake servername by appending ','
|
||||||
rootServer = tracker.getRootRegionLocation().toString() + ","
|
metaServer = tracker.getMetaRegionLocation().toString() + ","
|
||||||
tracker.stop()
|
tracker.stop()
|
||||||
return rootServer
|
return metaServer
|
||||||
end
|
end
|
||||||
table = nil
|
table = nil
|
||||||
if r.isMetaRegion()
|
|
||||||
table = getRootTable(admin.getConfiguration())
|
|
||||||
else
|
|
||||||
table = getMetaTable(admin.getConfiguration())
|
table = getMetaTable(admin.getConfiguration())
|
||||||
end
|
|
||||||
g = Get.new(r.getRegionName())
|
g = Get.new(r.getRegionName())
|
||||||
g.addColumn(HConstants::CATALOG_FAMILY, HConstants::SERVER_QUALIFIER)
|
g.addColumn(HConstants::CATALOG_FAMILY, HConstants::SERVER_QUALIFIER)
|
||||||
g.addColumn(HConstants::CATALOG_FAMILY, HConstants::STARTCODE_QUALIFIER)
|
g.addColumn(HConstants::CATALOG_FAMILY, HConstants::STARTCODE_QUALIFIER)
|
||||||
|
@ -259,10 +248,8 @@ end
|
||||||
|
|
||||||
# Now get list of regions on targetServer
|
# Now get list of regions on targetServer
|
||||||
def getRegions(config, servername)
|
def getRegions(config, servername)
|
||||||
connection = HConnectionManager::getConnection(config)
|
connection = HConnectionManager::getConnection(config);
|
||||||
parts = servername.split(',')
|
return ProtobufUtil::getOnlineRegions(connection.getAdmin(ServerName.new(servername)));
|
||||||
rs = connection.getHRegionConnection(parts[0], parts[1].to_i)
|
|
||||||
return rs.getOnlineRegions()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def deleteFile(filename)
|
def deleteFile(filename)
|
||||||
|
@ -280,8 +267,7 @@ def writeFile(filename, regions)
|
||||||
dos.writeInt(regions.size())
|
dos.writeInt(regions.size())
|
||||||
# Write actual region names.
|
# Write actual region names.
|
||||||
for r in regions
|
for r in regions
|
||||||
bytes = Writables.getBytes(r)
|
Bytes.writeByteArray(dos, r.toByteArray())
|
||||||
Bytes.writeByteArray(dos, bytes)
|
|
||||||
end
|
end
|
||||||
dos.close()
|
dos.close()
|
||||||
end
|
end
|
||||||
|
@ -298,7 +284,7 @@ def readFile(filename)
|
||||||
regions = java.util.ArrayList.new(count)
|
regions = java.util.ArrayList.new(count)
|
||||||
index = 0
|
index = 0
|
||||||
while index < count
|
while index < count
|
||||||
regions.add(Writables.getHRegionInfo(Bytes.readByteArray(dis)))
|
regions.add(HRegionInfo.parseFromOrNull(Bytes.readByteArray(dis)))
|
||||||
index = index + 1
|
index = index + 1
|
||||||
end
|
end
|
||||||
dis.close()
|
dis.close()
|
||||||
|
|
|
@ -53,7 +53,8 @@ import org.apache.hadoop.hbase.client.HTable
|
||||||
import org.apache.hadoop.hbase.client.Scan
|
import org.apache.hadoop.hbase.client.Scan
|
||||||
import org.apache.hadoop.hbase.filter.FirstKeyOnlyFilter
|
import org.apache.hadoop.hbase.filter.FirstKeyOnlyFilter
|
||||||
import org.apache.hadoop.hbase.util.Bytes
|
import org.apache.hadoop.hbase.util.Bytes
|
||||||
import org.apache.hadoop.hbase.util.Writables
|
import org.apache.hadoop.hbase.HRegionInfo
|
||||||
|
import org.apache.hadoop.hbase.client.MetaScanner
|
||||||
|
|
||||||
# disable debug logging on this script for clarity
|
# disable debug logging on this script for clarity
|
||||||
log_level = org.apache.log4j.Level::ERROR
|
log_level = org.apache.log4j.Level::ERROR
|
||||||
|
@ -114,7 +115,7 @@ while iter.hasNext
|
||||||
# Gone too far, break
|
# Gone too far, break
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
region = Writables.getHRegionInfo result.getValue(INFO, REGION_INFO)
|
region = HRegionInfo.getHRegionInfo result
|
||||||
if not region.isOffline
|
if not region.isOffline
|
||||||
# only include regions that should be online
|
# only include regions that should be online
|
||||||
meta_count += 1
|
meta_count += 1
|
||||||
|
@ -122,9 +123,9 @@ while iter.hasNext
|
||||||
end
|
end
|
||||||
scanner.close
|
scanner.close
|
||||||
# If we're trying to see the status of all HBase tables, we need to include the
|
# If we're trying to see the status of all HBase tables, we need to include the
|
||||||
# -ROOT- & .META. tables, that are not included in our scan
|
# .META. table, that is not included in our scan
|
||||||
if $tablename.nil?
|
if $tablename.nil?
|
||||||
meta_count += 2
|
meta_count += 1
|
||||||
end
|
end
|
||||||
|
|
||||||
# query the master to see how many regions are on region servers
|
# query the master to see how many regions are on region servers
|
||||||
|
@ -135,7 +136,7 @@ while true
|
||||||
if $tablename.nil?
|
if $tablename.nil?
|
||||||
server_count = admin.getClusterStatus().getRegionsCount()
|
server_count = admin.getClusterStatus().getRegionsCount()
|
||||||
else
|
else
|
||||||
server_count = $tableq.getRegionsInfo().size()
|
server_count = MetaScanner::allTableRegions(config,$tablename.to_java_bytes,false).size()
|
||||||
end
|
end
|
||||||
print "Region Status: #{server_count} / #{meta_count}\n"
|
print "Region Status: #{server_count} / #{meta_count}\n"
|
||||||
if SHOULD_WAIT and server_count < meta_count
|
if SHOULD_WAIT and server_count < meta_count
|
||||||
|
|
Loading…
Reference in New Issue