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.commons.lang.math.RandomUtils;
24 import org.apache.hadoop.hbase.HBaseTestingUtility;
25 import org.apache.hadoop.hbase.HRegionInfo;
26 import org.apache.hadoop.hbase.TableName;
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 MergeRandomAdjacentRegionsOfTableAction extends Action {
35 private static final Logger LOG =
36 LoggerFactory.getLogger(MergeRandomAdjacentRegionsOfTableAction.class);
37 private final TableName tableName;
38 private final long sleepTime;
39
40 public MergeRandomAdjacentRegionsOfTableAction(TableName tableName) {
41 this(-1, tableName);
42 }
43
44 public MergeRandomAdjacentRegionsOfTableAction(int sleepTime, TableName tableName) {
45 this.tableName = tableName;
46 this.sleepTime = sleepTime;
47 }
48
49 @Override protected Logger getLogger() {
50 return LOG;
51 }
52
53 @Override
54 public void perform() throws Exception {
55 HBaseTestingUtility util = context.getHBaseIntegrationTestingUtility();
56 Admin admin = util.getHBaseAdmin();
57
58 getLogger().info("Performing action: Merge random adjacent regions of table " + tableName);
59 List<HRegionInfo> regions = admin.getTableRegions(tableName);
60 if (regions == null || regions.size() < 2) {
61 getLogger().info("Table " + tableName + " doesn't have enough regions to merge");
62 return;
63 }
64
65 int i = RandomUtils.nextInt(regions.size() - 1);
66 HRegionInfo a = regions.get(i++);
67 HRegionInfo b = regions.get(i);
68 getLogger().debug("Merging " + a.getRegionNameAsString() + " and " + b.getRegionNameAsString());
69
70
71 if (context.isStopping()) {
72 return;
73 }
74
75 try {
76 admin.mergeRegions(a.getEncodedNameAsBytes(), b.getEncodedNameAsBytes(), false);
77 } catch (Exception ex) {
78 getLogger().warn("Merge failed, might be caused by other chaos: " + ex.getMessage());
79 }
80 if (sleepTime > 0) {
81 Thread.sleep(sleepTime);
82 }
83 }
84 }