~ubuntu-branches/ubuntu/precise/hbase/precise

« back to all changes in this revision

Viewing changes to src/contrib/transactional/src/java/org/apache/hadoop/hbase/regionserver/transactional/CleanOldTransactionsChore.java

  • Committer: Bazaar Package Importer
  • Author(s): Thomas Koch
  • Date: 2010-05-06 14:20:42 UTC
  • Revision ID: james.westby@ubuntu.com-20100506142042-r3hlvgxdcpb8tynl
Tags: upstream-0.20.4+dfsg1
ImportĀ upstreamĀ versionĀ 0.20.4+dfsg1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/**
 
2
 * Copyright 2009 The Apache Software Foundation
 
3
 *
 
4
 * Licensed to the Apache Software Foundation (ASF) under one
 
5
 * or more contributor license agreements.  See the NOTICE file
 
6
 * distributed with this work for additional information
 
7
 * regarding copyright ownership.  The ASF licenses this file
 
8
 * to you under the Apache License, Version 2.0 (the
 
9
 * "License"); you may not use this file except in compliance
 
10
 * with the License.  You may obtain a copy of the License at
 
11
 *
 
12
 *     http://www.apache.org/licenses/LICENSE-2.0
 
13
 *
 
14
 * Unless required by applicable law or agreed to in writing, software
 
15
 * distributed under the License is distributed on an "AS IS" BASIS,
 
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
17
 * See the License for the specific language governing permissions and
 
18
 * limitations under the License.
 
19
 */
 
20
package org.apache.hadoop.hbase.regionserver.transactional;
 
21
 
 
22
import java.util.concurrent.atomic.AtomicBoolean;
 
23
 
 
24
import org.apache.hadoop.hbase.Chore;
 
25
import org.apache.hadoop.hbase.regionserver.HRegion;
 
26
 
 
27
/**
 
28
 * Cleans up committed transactions when they are no longer needed to verify
 
29
 * pending transactions.
 
30
 */
 
31
class CleanOldTransactionsChore extends Chore {
 
32
 
 
33
  private static final String SLEEP_CONF = "hbase.transaction.clean.sleep";
 
34
  private static final int DEFAULT_SLEEP = 60 * 1000;
 
35
 
 
36
  private final TransactionalRegionServer regionServer;
 
37
 
 
38
  /**
 
39
   * @param regionServer
 
40
   * @param stopRequest
 
41
   */
 
42
  public CleanOldTransactionsChore(
 
43
      final TransactionalRegionServer regionServer,
 
44
      final AtomicBoolean stopRequest) {
 
45
    super(regionServer.getConfiguration().getInt(SLEEP_CONF, DEFAULT_SLEEP),
 
46
        stopRequest);
 
47
    this.regionServer = regionServer;
 
48
  }
 
49
 
 
50
  @Override
 
51
  protected void chore() {
 
52
    for (HRegion region : regionServer.getOnlineRegions()) {
 
53
      ((TransactionalRegion) region).removeUnNeededCommitedTransactions();
 
54
    }
 
55
  }
 
56
}