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 org.apache.hadoop.hbase.HBaseTestingUtility;
22 import org.apache.hadoop.hbase.TableName;
23 import org.apache.hadoop.hbase.client.Admin;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26
27
28
29
30 public class FlushTableAction extends Action {
31 private static final Logger LOG = LoggerFactory.getLogger(FlushTableAction.class);
32 private final long sleepTime;
33 private final TableName tableName;
34
35 public FlushTableAction(TableName tableName) {
36 this(-1, tableName);
37 }
38
39 public FlushTableAction(int sleepTime, TableName tableName) {
40 this.sleepTime = sleepTime;
41 this.tableName = tableName;
42 }
43
44 @Override protected Logger getLogger() {
45 return LOG;
46 }
47
48 @Override
49 public void perform() throws Exception {
50 HBaseTestingUtility util = context.getHBaseIntegrationTestingUtility();
51 Admin admin = util.getHBaseAdmin();
52
53
54 if (context.isStopping()) {
55 return;
56 }
57
58 getLogger().info("Performing action: Flush table " + tableName);
59 try {
60 admin.flush(tableName);
61 } catch (Exception ex) {
62 getLogger().warn("Flush failed, might be caused by other chaos: " + ex.getMessage());
63 }
64 if (sleepTime > 0) {
65 Thread.sleep(sleepTime);
66 }
67 }
68 }