1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package org.apache.hadoop.hbase.chaos.actions;
20
21 import java.util.List;
22
23 import org.apache.hadoop.hbase.HBaseTestingUtility;
24 import org.apache.hadoop.hbase.HRegionInfo;
25 import org.apache.hadoop.hbase.TableName;
26 import org.apache.hadoop.hbase.chaos.monkies.PolicyBasedChaosMonkey;
27 import org.apache.hadoop.hbase.client.Admin;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30
31
32
33
34 public class MoveRandomRegionOfTableAction extends Action {
35 private static final Logger LOG =
36 LoggerFactory.getLogger(MoveRandomRegionOfTableAction.class);
37 private final long sleepTime;
38 private final TableName tableName;
39
40 public MoveRandomRegionOfTableAction(TableName tableName) {
41 this(-1, tableName);
42 }
43
44 public MoveRandomRegionOfTableAction(long sleepTime, TableName tableName) {
45 this.sleepTime = sleepTime;
46 this.tableName = tableName;
47 }
48
49 @Override protected Logger getLogger() {
50 return LOG;
51 }
52
53 @Override
54 public void perform() throws Exception {
55 if (sleepTime > 0) {
56 Thread.sleep(sleepTime);
57 }
58
59 HBaseTestingUtility util = context.getHBaseIntegrationTestingUtility();
60 Admin admin = util.getHBaseAdmin();
61
62 getLogger().info("Performing action: Move random region of table " + tableName);
63 List<HRegionInfo> regions = admin.getTableRegions(tableName);
64 if (regions == null || regions.isEmpty()) {
65 getLogger().info("Table " + tableName + " doesn't have regions to move");
66 return;
67 }
68
69 HRegionInfo region = PolicyBasedChaosMonkey.selectRandomItem(
70 regions.toArray(new HRegionInfo[regions.size()]));
71 getLogger().debug("Unassigning region " + region.getRegionNameAsString());
72 admin.unassign(region.getRegionName(), false);
73 if (sleepTime > 0) {
74 Thread.sleep(sleepTime);
75 }
76 }
77 }