hbase git commit: HBASE-14925 Develop HBase shell command/tool to list table's region info through command line

2017-04-28 Thread ashishsinghi
Repository: hbase
Updated Branches:
  refs/heads/branch-1 cdda1d030 -> 3765e7bed


HBASE-14925 Develop HBase shell command/tool to list table's region info 
through command line

Signed-off-by: Ashish Singhi 


Project: http://git-wip-us.apache.org/repos/asf/hbase/repo
Commit: http://git-wip-us.apache.org/repos/asf/hbase/commit/3765e7be
Tree: http://git-wip-us.apache.org/repos/asf/hbase/tree/3765e7be
Diff: http://git-wip-us.apache.org/repos/asf/hbase/diff/3765e7be

Branch: refs/heads/branch-1
Commit: 3765e7bedb937044c8e0a416a7b44d41165ee48c
Parents: cdda1d0
Author: Karan Mehta 
Authored: Fri Apr 28 14:08:04 2017 +0530
Committer: Ashish Singhi 
Committed: Fri Apr 28 14:08:04 2017 +0530

--
 hbase-shell/src/main/ruby/shell.rb  |  1 +
 .../main/ruby/shell/commands/list_regions.rb| 76 
 2 files changed, 77 insertions(+)
--


http://git-wip-us.apache.org/repos/asf/hbase/blob/3765e7be/hbase-shell/src/main/ruby/shell.rb
--
diff --git a/hbase-shell/src/main/ruby/shell.rb 
b/hbase-shell/src/main/ruby/shell.rb
index 9576cc7..99adf73 100644
--- a/hbase-shell/src/main/ruby/shell.rb
+++ b/hbase-shell/src/main/ruby/shell.rb
@@ -272,6 +272,7 @@ Shell.load_command_group(
 alter_async
 get_table
 locate_region
+list_regions
   ],
   :aliases => {
 'describe' => ['desc']

http://git-wip-us.apache.org/repos/asf/hbase/blob/3765e7be/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
--
diff --git a/hbase-shell/src/main/ruby/shell/commands/list_regions.rb 
b/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
new file mode 100644
index 000..527a6cb
--- /dev/null
+++ b/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
@@ -0,0 +1,76 @@
+#
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+module Shell
+  module Commands
+class ListRegions < Command
+  def help
+
+return< list_regions 'table_name'
+hbase> list_regions 'table_name', 'server_name'
+
+EOF
+return
+  end
+
+  def command(table_name, region_server_name = "")
+admin_instance = admin.instance_variable_get("@admin")
+conn_instance = admin_instance.getConnection()
+cluster_status = admin_instance.getClusterStatus()
+hregion_locator_instance = 
conn_instance.getRegionLocator(TableName.valueOf(table_name))
+hregion_locator_list = hregion_locator_instance.getAllRegionLocations()
+results = Array.new
+
+begin
+  hregion_locator_list.each do |hregion|
+hregion_info = hregion.getRegionInfo()
+server_name = hregion.getServerName()
+if hregion.getServerName().toString.start_with? region_server_name
+  startKey = Bytes.toString(hregion.getRegionInfo().getStartKey())
+  endKey = Bytes.toString(hregion.getRegionInfo().getEndKey())
+  region_load_map = 
cluster_status.getLoad(server_name).getRegionsLoad()
+  region_load = region_load_map.get(hregion_info.getRegionName())
+  region_store_file_size = region_load.getStorefileSizeMB()
+  region_requests = region_load.getRequestsCount()
+  results << { "server" => hregion.getServerName().toString(), 
"name" => hregion_info.getRegionNameAsString(), "startkey" => startKey, 
"endkey" => endKey, "size" => region_store_file_size, "requests" => 
region_requests }
+end
+  end
+ensure
+  hregion_locator_instance.close()
+end
+
+@end_time = Time.now
+
+printf("%-60s | %-60s | %-15s | %-15s | %-20s | %-20s", "SERVER_NAME", 
"REGION_NAME", "START_KEY", "END_KEY", "SIZE", "REQ");
+printf("\n")
+for result in results
+  printf("%-60s | %-60s | %-15s | %-15s | %-20s | %-20s", 
result["server"], result["name"], result["startkey"], result["endkey"], 
result["size"], result["requests"]);
+printf("\n")
+end
+printf("%d rows", results.size)
+

hbase git commit: HBase-14925 Develop HBase shell command/tool to list table's region info through command line

2017-04-28 Thread ashishsinghi
Repository: hbase
Updated Branches:
  refs/heads/master c4cbb419a -> 68b2e0f7d


HBase-14925 Develop HBase shell command/tool to list table's region info 
through command line

Signed-off-by: Ashish Singhi 


Project: http://git-wip-us.apache.org/repos/asf/hbase/repo
Commit: http://git-wip-us.apache.org/repos/asf/hbase/commit/68b2e0f7
Tree: http://git-wip-us.apache.org/repos/asf/hbase/tree/68b2e0f7
Diff: http://git-wip-us.apache.org/repos/asf/hbase/diff/68b2e0f7

Branch: refs/heads/master
Commit: 68b2e0f7d94c02aa82ac89f2ec2f052bdcd58704
Parents: c4cbb41
Author: Karan Mehta 
Authored: Fri Apr 28 14:06:03 2017 +0530
Committer: Ashish Singhi 
Committed: Fri Apr 28 14:06:03 2017 +0530

--
 hbase-shell/src/main/ruby/shell.rb  |  1 +
 .../main/ruby/shell/commands/list_regions.rb| 76 
 2 files changed, 77 insertions(+)
--


http://git-wip-us.apache.org/repos/asf/hbase/blob/68b2e0f7/hbase-shell/src/main/ruby/shell.rb
--
diff --git a/hbase-shell/src/main/ruby/shell.rb 
b/hbase-shell/src/main/ruby/shell.rb
index fc55f94..a6aba76 100644
--- a/hbase-shell/src/main/ruby/shell.rb
+++ b/hbase-shell/src/main/ruby/shell.rb
@@ -285,6 +285,7 @@ Shell.load_command_group(
 alter_async
 get_table
 locate_region
+list_regions
   ],
   :aliases => {
 'describe' => ['desc']

http://git-wip-us.apache.org/repos/asf/hbase/blob/68b2e0f7/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
--
diff --git a/hbase-shell/src/main/ruby/shell/commands/list_regions.rb 
b/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
new file mode 100644
index 000..527a6cb
--- /dev/null
+++ b/hbase-shell/src/main/ruby/shell/commands/list_regions.rb
@@ -0,0 +1,76 @@
+#
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+module Shell
+  module Commands
+class ListRegions < Command
+  def help
+
+return< list_regions 'table_name'
+hbase> list_regions 'table_name', 'server_name'
+
+EOF
+return
+  end
+
+  def command(table_name, region_server_name = "")
+admin_instance = admin.instance_variable_get("@admin")
+conn_instance = admin_instance.getConnection()
+cluster_status = admin_instance.getClusterStatus()
+hregion_locator_instance = 
conn_instance.getRegionLocator(TableName.valueOf(table_name))
+hregion_locator_list = hregion_locator_instance.getAllRegionLocations()
+results = Array.new
+
+begin
+  hregion_locator_list.each do |hregion|
+hregion_info = hregion.getRegionInfo()
+server_name = hregion.getServerName()
+if hregion.getServerName().toString.start_with? region_server_name
+  startKey = Bytes.toString(hregion.getRegionInfo().getStartKey())
+  endKey = Bytes.toString(hregion.getRegionInfo().getEndKey())
+  region_load_map = 
cluster_status.getLoad(server_name).getRegionsLoad()
+  region_load = region_load_map.get(hregion_info.getRegionName())
+  region_store_file_size = region_load.getStorefileSizeMB()
+  region_requests = region_load.getRequestsCount()
+  results << { "server" => hregion.getServerName().toString(), 
"name" => hregion_info.getRegionNameAsString(), "startkey" => startKey, 
"endkey" => endKey, "size" => region_store_file_size, "requests" => 
region_requests }
+end
+  end
+ensure
+  hregion_locator_instance.close()
+end
+
+@end_time = Time.now
+
+printf("%-60s | %-60s | %-15s | %-15s | %-20s | %-20s", "SERVER_NAME", 
"REGION_NAME", "START_KEY", "END_KEY", "SIZE", "REQ");
+printf("\n")
+for result in results
+  printf("%-60s | %-60s | %-15s | %-15s | %-20s | %-20s", 
result["server"], result["name"], result["startkey"], result["endkey"], 
result["size"], result["requests"]);
+printf("\n")
+end
+printf("%d rows", results.size)
+
+