diff --git a/checkstyle.xml b/checkstyle.xml index b404f4b..d2d98cc 100644 --- a/checkstyle.xml +++ b/checkstyle.xml @@ -17,118 +17,118 @@ --> - - + "-//Puppy Crawl//DTD Check Configuration 1.3//EN" + "http://www.puppycrawl.com/dtds/configuration_1_3.dtd"> + + - - - + + + - + - + - - + + - - + + - - + + - - + + - - + + - - - + + + - + - - + + - - - - - - - - - - + + + + + + + + + + - - + + - + - - - + + + - - + + - - - - - - + + + + + + - + - + - + - - - - - - + + + + + + + MOD_ASSIGN, NOT_EQUAL, PLUS, PLUS_ASSIGN, QUESTION, SL, SL_ASSIGN, SR_ASSIGN, STAR, STAR_ASSIGN"/> - + - - - + + + - - - + + + - \ No newline at end of file + diff --git a/pom.xml b/pom.xml index bdd23cf..fd8ec45 100644 --- a/pom.xml +++ b/pom.xml @@ -15,7 +15,8 @@ limitations under the License. --> - + 4.0.0 org.sonatype.oss @@ -318,7 +319,7 @@ - + @@ -331,7 +332,7 @@ - + @@ -449,7 +450,7 @@ java8 - 1.8 + 1.8 diff --git a/src/main/java/kr/co/vcnc/haeinsa/ForwardingHaeinsaTable.java b/src/main/java/kr/co/vcnc/haeinsa/ForwardingHaeinsaTable.java index 27e0425..12909e2 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/ForwardingHaeinsaTable.java +++ b/src/main/java/kr/co/vcnc/haeinsa/ForwardingHaeinsaTable.java @@ -34,10 +34,6 @@ public class ForwardingHaeinsaTable extends ForwardingObject implements HaeinsaTableIfaceInternal { private final HaeinsaTableIfaceInternal delegate; - /** - * Constructor - * @param haeinsaTable HaeinsaTable - */ public ForwardingHaeinsaTable(HaeinsaTableIface haeinsaTable) { Preconditions.checkArgument(haeinsaTable instanceof HaeinsaTableIfaceInternal); this.delegate = (HaeinsaTableIfaceInternal) haeinsaTable; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaColumnTracker.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaColumnTracker.java index d274ca1..68f6ade 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaColumnTracker.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaColumnTracker.java @@ -22,6 +22,7 @@ import org.apache.hadoop.hbase.util.Bytes; +import com.google.common.collect.Maps; import com.google.common.collect.Sets; /** @@ -32,8 +33,7 @@ */ public class HaeinsaColumnTracker { // { family -> qualifier } - private final Map> familyMap = - new TreeMap>(Bytes.BYTES_COMPARATOR); + private final Map> familyMap = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); private final byte[] minColumn; private final boolean minColumnInclusive; @@ -44,19 +44,11 @@ public class HaeinsaColumnTracker { * Constructor of HaeinsaColumnTracker. *

* If this ColumnTracker track {@link HaeinsaScan}, minColumn, maxColumn - * should be null and minColumnInclusive, maxColumnInclusive should be - * false. - * - * @param familyMap - * - * @param minColumn - * @param minColumnInclusive - * @param maxColumn - * @param maxColumnInclusive + * should be null and minColumnInclusive, maxColumnInclusive should be false. */ public HaeinsaColumnTracker(Map> familyMap, - byte[] minColumn, boolean minColumnInclusive, - byte[] maxColumn, boolean maxColumnInclusive) { + byte[] minColumn, boolean minColumnInclusive, + byte[] maxColumn, boolean maxColumnInclusive) { this.minColumn = minColumn; this.maxColumn = maxColumn; this.minColumnInclusive = minColumnInclusive; @@ -76,9 +68,6 @@ public HaeinsaColumnTracker(Map> familyMap, * Return true if qualifier of kv is placed between minColumn and maxColumn. *

* Using lexicographical ordering to compare byte[] - * - * @param kv - * @return */ public boolean isColumnInclusive(HaeinsaKeyValue kv) { int cmpMin = 1; @@ -121,7 +110,6 @@ public boolean isColumnInclusive(HaeinsaKeyValue kv) { * * * @param kv HaeinsaKeyValue which will be checked. - * @return */ public boolean isMatched(HaeinsaKeyValue kv) { // If familyMap is empty, then Haeinsa transaction assumes diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaConstants.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaConstants.java index fb1a32f..13808fa 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaConstants.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaConstants.java @@ -26,8 +26,7 @@ * Static Class of Constants for Haeinsa */ public final class HaeinsaConstants { - private HaeinsaConstants() { - } + private HaeinsaConstants() {} /** * Haeinsa protocol version of this release. diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDelete.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDelete.java index 499af6f..fe109b8 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDelete.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDelete.java @@ -32,7 +32,7 @@ import com.google.common.collect.Sets; /** - * Implementation of {@link HaeinsaMuation} which only contains HaeinsaKeyValue + * Implementation of {@link HaeinsaMutation} which only contains HaeinsaKeyValue * with {@link Type#DeleteFamily} and {@link Type#DeleteColumn} identifier. * HaeinsaPut can be analogous to {@link Delete} class in HBase. *

@@ -121,9 +121,10 @@ public TMutation toTMutation() { newTRemove.addToRemoveFamilies(ByteBuffer.wrap(kv.getFamily())); break; } - default: + default: { break; } + } } newTMutation.setRemove(newTRemove); return newTMutation; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDeleteTracker.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDeleteTracker.java index 9fcd490..9139e2d 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDeleteTracker.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaDeleteTracker.java @@ -31,11 +31,10 @@ public class HaeinsaDeleteTracker { private final NavigableMap> cells = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); /** - * Update family map or column map if kv is not exist in map or sequenceId - * is lower. + * Update family map or column map if kv is not exist in map or sequenceId is lower. * - * @param kv - HaeinsaKeyValue to track - * @param sequenceID - sequence ID, lower is newer. + * @param kv HaeinsaKeyValue to track + * @param sequenceID sequence ID, lower is newer. */ public void add(HaeinsaKeyValue kv, long sequenceID) { switch (kv.getType()) { @@ -60,17 +59,14 @@ public void add(HaeinsaKeyValue kv, long sequenceID) { } break; } - default: + default: { break; } + } } /** - * - * @param kv - * @param sequenceID - * @return Return true if kv is deleted after sequenceID (lower sequenceID), - * return false otherwise. + * @return Return true if kv is deleted after sequenceID (lower sequenceID), return false otherwise. */ public boolean isDeleted(HaeinsaKeyValue kv, long sequenceID) { // check family diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaGet.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaGet.java index 86b074f..9ffba12 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaGet.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaGet.java @@ -23,6 +23,8 @@ import org.apache.hadoop.hbase.client.Get; import org.apache.hadoop.hbase.util.Bytes; +import com.google.common.collect.Maps; + /** * HaeinsaGet can be analogous to {@link Get} class in HBase. *

@@ -30,8 +32,7 @@ */ public class HaeinsaGet extends HaeinsaQuery { private byte[] row; - private Map> familyMap = - new TreeMap>(Bytes.BYTES_COMPARATOR); + private Map> familyMap = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); /** * Create a Get operation for the specified row. diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaIntraScan.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaIntraScan.java index 0c2645c..a2a7e81 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaIntraScan.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaIntraScan.java @@ -16,11 +16,12 @@ package kr.co.vcnc.haeinsa; import java.util.NavigableSet; -import java.util.TreeSet; import org.apache.hadoop.hbase.filter.ColumnRangeFilter; import org.apache.hadoop.hbase.util.Bytes; +import com.google.common.collect.Sets; + /** * Custom integration of {@link ColumnRangeFilter} in Haeinsa. In contrast to * {@link HaeinsaScan}, HaeinsaIntraScan can be used to retrieve range of column @@ -40,11 +41,11 @@ public class HaeinsaIntraScan extends HaeinsaQuery { private int batch = 32; // if this set is empty, then scan every family - private final NavigableSet families = new TreeSet(Bytes.BYTES_COMPARATOR); + private final NavigableSet families = Sets.newTreeSet(Bytes.BYTES_COMPARATOR); public HaeinsaIntraScan(final byte[] row, - final byte[] minColumn, boolean minColumnInclusive, - final byte[] maxColumn, boolean maxColumnInclusive) { + final byte[] minColumn, boolean minColumnInclusive, + final byte[] maxColumn, boolean maxColumnInclusive) { this.row = row; this.minColumn = minColumn; this.minColumnInclusive = minColumnInclusive; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValue.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValue.java index 76f0d80..e5199f2 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValue.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValue.java @@ -36,7 +36,7 @@ * same Enum with {@link org.apache.hadoop.hbase.KeyValue.Type}. *

* HaeinsaKeyValue has public static comparator which can be used in - * navigableMap. This comparator is ComparisionChain of {@link NullableCompator} + * navigableMap. This comparator is ComparisionChain of {@link NullableComparator} * wrapped {@link org.apache.hadoop.hbase.util.Bytes#BYTES_COMPARATOR}. The * order of comparisonChain is row, family, qualifier, value and type. */ @@ -45,9 +45,9 @@ public class HaeinsaKeyValue { @Override public int compare(HaeinsaKeyValue o1, HaeinsaKeyValue o2) { return ComparisonChain.start() - .compare(o1.getRow(), o2.getRow(), new NullableComparator(Bytes.BYTES_COMPARATOR)) - .compare(o1.getFamily(), o2.getFamily(), new NullableComparator(Bytes.BYTES_COMPARATOR)) - .compare(o1.getQualifier(), o2.getQualifier(), new NullableComparator(Bytes.BYTES_COMPARATOR)) + .compare(o1.getRow(), o2.getRow(), new NullableComparator<>(Bytes.BYTES_COMPARATOR)) + .compare(o1.getFamily(), o2.getFamily(), new NullableComparator<>(Bytes.BYTES_COMPARATOR)) + .compare(o1.getQualifier(), o2.getQualifier(), new NullableComparator<>(Bytes.BYTES_COMPARATOR)) .compare(o2.getType().getCode() & 0xFF, o1.getType().getCode() & 0xFF) .result(); } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValueScanner.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValueScanner.java index b4186e1..179ae19 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValueScanner.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaKeyValueScanner.java @@ -35,7 +35,6 @@ */ public interface HaeinsaKeyValueScanner { Comparator COMPARATOR = new Comparator() { - @Override public int compare(HaeinsaKeyValueScanner o1, HaeinsaKeyValueScanner o2) { return ComparisonChain.start() @@ -60,9 +59,7 @@ public int compare(HaeinsaKeyValueScanner o1, HaeinsaKeyValueScanner o2) { HaeinsaKeyValue next() throws IOException; /** - * * @return Return TRowLock if exist in HaeinsaKeyValue. Otherwise, return null - * @throws IOException */ TRowLock peekLock() throws IOException; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaMutation.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaMutation.java index 43ad237..ffd88a5 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaMutation.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaMutation.java @@ -29,6 +29,7 @@ import org.apache.hadoop.hbase.util.Bytes; import com.google.common.collect.Iterables; +import com.google.common.collect.Maps; /** * HaeinsaMutation is abstract class equivalent to auto-generated thrift class {@link TMutation}. @@ -41,13 +42,12 @@ * These late Get/Scan operations can see the mutated view of specific row * even before those mutations are committed to HBase. *

- * HaeinsaMutation provides {@link HaeinsaKeyValueScanner} interface by {@link #getScanner()} method. + * HaeinsaMutation provides {@link HaeinsaKeyValueScanner} interface by {@link #getScanner(long)} method. */ public abstract class HaeinsaMutation extends HaeinsaOperation { protected byte[] row; // { family -> HaeinsaKeyValue } - protected Map> familyMap = - new TreeMap>(Bytes.BYTES_COMPARATOR); + protected Map> familyMap = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); /** * Method for retrieving the put's familyMap @@ -103,11 +103,10 @@ public int compareTo(final Row d) { public abstract TMutation toTMutation(); /** - * Return {@link #HaeinsaKeyValueScanner} interface for single row. + * Return {@link HaeinsaKeyValueScanner} interface for single row. * * @param sequenceID sequence id represent which Scanner is newer one. Lower - * id is newer one. - * @return + * id is newer one. */ public HaeinsaKeyValueScanner getScanner(final long sequenceID) { return new MutationScanner(sequenceID); @@ -136,7 +135,7 @@ private class MutationScanner implements HaeinsaKeyValueScanner { * of values. Otherwise, the way to generate iterator should be changed. * * @param sequenceID sequence id represent which Scanner is newer one. - * Lower id is newer one. + * Lower id is newer one. */ public MutationScanner(long sequenceID) { this.sequenceID = sequenceID; @@ -172,7 +171,6 @@ public TRowLock peekLock() throws IOException { } @Override - public void close() { - } + public void close() {} } } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaOperation.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaOperation.java index 6897822..41547d3 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaOperation.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaOperation.java @@ -15,5 +15,4 @@ */ package kr.co.vcnc.haeinsa; -public abstract class HaeinsaOperation { -} +public abstract class HaeinsaOperation {} diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaPut.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaPut.java index 66044b6..f91a5f7 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaPut.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaPut.java @@ -17,7 +17,6 @@ import java.util.Map; import java.util.NavigableSet; -import java.util.TreeMap; import kr.co.vcnc.haeinsa.thrift.generated.TCellKey; import kr.co.vcnc.haeinsa.thrift.generated.TKeyValue; @@ -32,10 +31,11 @@ import com.google.common.base.Preconditions; import com.google.common.collect.Iterables; +import com.google.common.collect.Maps; import com.google.common.collect.Sets; /** - * Implementation of {@link HaeinsaMuation} which only contains HaeinsaKeyValue + * Implementation of {@link HaeinsaMutation} which only contains HaeinsaKeyValue * with {@link Type#Put} identifier. HaeinsaPut can be analogous to {@link Put} * class in HBase. *

@@ -54,7 +54,7 @@ public HaeinsaPut(byte[] row) { */ public HaeinsaPut(HaeinsaPut putToCopy) { this(putToCopy.getRow()); - this.familyMap = new TreeMap>(Bytes.BYTES_COMPARATOR); + this.familyMap = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); for (Map.Entry> entry : putToCopy.getFamilyMap().entrySet()) { this.familyMap.put(entry.getKey(), entry.getValue()); } @@ -98,7 +98,7 @@ private HaeinsaKeyValue createPutKeyValue(byte[] family, byte[] qualifier, byte[ * * @param family column family * @return a set of KeyValue objects, returns an empty set if one doesn't - * exist. + * exist. */ private NavigableSet getKeyValueSet(byte[] family) { NavigableSet set = familyMap.get(family); diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaQuery.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaQuery.java index dbaa112..76d3a65 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaQuery.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaQuery.java @@ -29,7 +29,7 @@ public abstract class HaeinsaQuery extends HaeinsaOperation { * cache is disabled for that family or entirely). * * @param cacheBlocks if false, default settings are overridden and blocks - * will not be cached + * will not be cached */ public void setCacheBlocks(boolean cacheBlocks) { this.cacheBlocks = cacheBlocks; @@ -39,7 +39,7 @@ public void setCacheBlocks(boolean cacheBlocks) { * Get whether blocks should be cached for this Scan. * * @return true if default setting of block caching should be used, false if - * blocks should not be cached + * blocks should not be cached */ public boolean getCacheBlocks() { return cacheBlocks; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResult.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResult.java index 191df74..313956d 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResult.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResult.java @@ -59,7 +59,7 @@ public HaeinsaKeyValue apply(KeyValue kv) { * Construct HaeinsaResultImpl from sorted list of HaeinsaKeyValue * * @param sortedKVs - Assumed that {@link HaeinsaKeyValue}s in sortedKVs - * have same row with first element and sorted in ascending order. + * have same row with first element and sorted in ascending order. */ public HaeinsaResult(List sortedKVs) { this.sortedKVs = sortedKVs; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResultScanner.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResultScanner.java index bad6676..2b56067 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResultScanner.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaResultScanner.java @@ -31,7 +31,7 @@ public interface HaeinsaResultScanner extends Closeable, Iterable * Grab the next row's worth of values. The scanner will return a Result. * * @return Result object if there is another row, null if the scanner is - * exhausted. + * exhausted. * @throws IOException e */ HaeinsaResult next() throws IOException; @@ -48,5 +48,4 @@ public interface HaeinsaResultScanner extends Closeable, Iterable */ @Override void close(); - } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaRowTransaction.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaRowTransaction.java index 7dab930..c64a27f 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaRowTransaction.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaRowTransaction.java @@ -79,11 +79,9 @@ public HaeinsaTableTransaction getTableTransaction() { } /** - * Return list of {@link HaeinsaKeyValueScanner}s which wrap mutations - - * (Put & Delete) contained inside instance. Also assign sequenceID to every - * {@link HaeinsaMutation#MutationScanner}. - * - * @return + * Return list of {@link HaeinsaKeyValueScanner}s which wrap mutations + * (Put and Delete) contained inside instance. Also assign sequenceID to every + * MutationScanner of {@link HaeinsaMutation}. */ public List getScanners() { List result = Lists.newArrayList(); diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaScan.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaScan.java index 8b0319c..1b90b25 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaScan.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaScan.java @@ -26,6 +26,8 @@ import org.apache.hadoop.hbase.client.Scan; import org.apache.hadoop.hbase.util.Bytes; +import com.google.common.collect.Maps; + /** * HaeinsaScan is analogous to {@link Scan} class in HBase. HaeinsaScan can be * used to retrieve range of row with specific family or (family, qualifier) @@ -43,8 +45,7 @@ public class HaeinsaScan extends HaeinsaQuery { private int caching = -1; // { family -> qualifier } - private Map> familyMap = - new TreeMap>(Bytes.BYTES_COMPARATOR); + private Map> familyMap = Maps.newTreeMap(Bytes.BYTES_COMPARATOR); /** * Create a HaeinsaScan instance. @@ -52,8 +53,7 @@ public class HaeinsaScan extends HaeinsaQuery { * If row is not specified for HaeinsaScan, the Scanner will start from the * beginning of the table. */ - public HaeinsaScan() { - } + public HaeinsaScan() {} /** * Create a Scan operation starting at the specified row. diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTable.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTable.java index 8c69ab2..70a994b 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTable.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTable.java @@ -99,10 +99,6 @@ public HTableDescriptor getTableDescriptor() throws IOException { * Get data from HBase without transaction. * {@link HaeinsaTransaction#commit()} to check or mutate lock column of the row scanned by this method. * This method can be used when read performance is important or strict consistency of the result is not matter. - * - * @param get - * @return - * @throws IOException */ private HaeinsaResult getWithoutTx(HaeinsaGet get) throws IOException { Get hGet = new Get(get.getRow()); @@ -204,7 +200,7 @@ public HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, byte[] f /** * Haeinsa implementation of {@link Scan}. * Scan range of row inside defined by {@link HaeinsaScan} in the context of transaction(tx). - * Return {@link #ClientScanner} which related to {@link HaeinsaTable} and {@link HaeinsaTransaction}. + * Return ClientScanner which related to {@link HaeinsaTable} and {@link HaeinsaTransaction}. *

* Return {@link SimpleClientScanner} which do not support transaction if tx is null. * User can use this feature if specific scan operation does not require strong consistency @@ -272,8 +268,6 @@ public HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, HaeinsaS * {@link HaeinsaTransaction#commit()} to check or mutate lock column of the row scanned by this method. * This method can be used when read performance is important or strict consistency of the result is not matter. * - * @param scan - * @return * @throws IOException IOException from HBase. */ private HaeinsaResultScanner getScannerWithoutTx(HaeinsaScan scan) throws IOException { @@ -297,7 +291,7 @@ private HaeinsaResultScanner getScannerWithoutTx(HaeinsaScan scan) throws IOExce /** * Haeinsa implementation of {@link ColumnRangeFilter}. * Scan range of column inside single row defined by {@link HaeinsaIntraScan} in the context of transaction(tx). - * Return {@link #ClientScanner} which related to {@link HaeinsaTable} and {@link HaeinsaTransaction}. + * Return {@link ClientScanner} which related to {@link HaeinsaTable} and {@link HaeinsaTransaction}. *

* Return {@link SimpleClientScanner} which do not support transaction if tx is null. * User can use this feature if specific intra-scan operation does not require strong consistency. @@ -313,7 +307,7 @@ public HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, HaeinsaI } // scan from startRow ( inclusive ) to startRow + 0x00 ( exclusive ) - Scan hScan = new Scan(intraScan.getRow(), Bytes.add(intraScan.getRow(), new byte[] { 0x00 })); + Scan hScan = new Scan(intraScan.getRow(), Bytes.add(intraScan.getRow(), new byte[]{0x00})); hScan.setBatch(intraScan.getBatch()); hScan.setCacheBlocks(intraScan.getCacheBlocks()); @@ -348,12 +342,10 @@ public HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, HaeinsaI * {@link HaeinsaTransaction#commit()} to check or mutate lock column of the row scanned by this method. * This method can be used when read performance is important or strict consistency of the result is not matter. * - * @param intraScan - * @return * @throws IOException IOException from HBase. */ private HaeinsaResultScanner getScannerWithoutTx(HaeinsaIntraScan intraScan) throws IOException { - Scan hScan = new Scan(intraScan.getRow(), Bytes.add(intraScan.getRow(), new byte[] { 0x00 })); + Scan hScan = new Scan(intraScan.getRow(), Bytes.add(intraScan.getRow(), new byte[]{0x00})); hScan.setBatch(intraScan.getBatch()); for (byte[] family : intraScan.getFamilies()) { @@ -388,21 +380,16 @@ public void put(HaeinsaTransaction tx, HaeinsaPut put) throws IOException { * Check rowState and whether it contains {@link TRowLock} already, create one if not. *

* Get {@link TRowLock} of the row from HBase if rowState does not contains it. - * If lock is not in stable state, try to recover it first by {@link HaeinsaTrasaction#recover()}. + * If lock is not in stable state, try to recover it first by {@link HaeinsaTransaction#recover(boolean)}. *

- * By calling this method proper time, {@link RowTransaction} inside {@link HaeinsaTransaction} can have + * By calling this method proper time, {@link HaeinsaRowTransaction} inside {@link HaeinsaTransaction} can have * {@link TRowLock} of the row when this method was called first time in the context of the transaction. * - * @param tx - * @param row - * @param tableState - * @param rowState - * @return * @throws IOException ConflictException, HBase IOException */ private HaeinsaRowTransaction checkOrRecoverLock(HaeinsaTransaction tx, - byte[] row, HaeinsaTableTransaction tableState, - @Nullable HaeinsaRowTransaction rowState) throws IOException { + byte[] row, HaeinsaTableTransaction tableState, + @Nullable HaeinsaRowTransaction rowState) throws IOException { if (rowState != null && rowState.getCurrent() != null) { // return rowState itself if rowState already exist and contains TRowLock return rowState; @@ -438,11 +425,10 @@ private HaeinsaRowTransaction checkOrRecoverLock(HaeinsaTransaction tx, * Return false if rowLock is in {@link TRowLockState#STABLE} state. * Throw {@link ConflictException} if rowLock is not in stable state and not expired yet. * - * @param rowLock * @return true - when lock is established but expired. / false - when there - * is no lock ( {@link TRowLockState#STABLE} ) + * is no lock ( {@link TRowLockState#STABLE} ) * @throws IOException {@link NotExpiredYetException} if lock is established and - * not expired. + * not expired. */ private boolean checkAndIsShouldRecover(TRowLock rowLock) throws IOException { if (rowLock.getState() != TRowLockState.STABLE) { @@ -455,12 +441,10 @@ private boolean checkAndIsShouldRecover(TRowLock rowLock) throws IOException { } /** - * Call {@link HaeinsaTransaction#recover()}. + * Call {@link HaeinsaTransaction#recover(boolean)}. * Abort or recover when there is failed transaction on the row, * throw {@link ConflictException} when there is ongoing transaction. * - * @param tx - * @param row * @throws IOException ConflictException, HBase IOException */ private void recover(HaeinsaTransaction tx, byte[] row) throws IOException { @@ -541,11 +525,8 @@ public void commitSingleRowPutOnly(HaeinsaRowTransaction rowState, byte[] row) t * If TRowLock is changed, it means transaction is failed, so throw * {@link ConflictException}. * - * @param prevRowLock - * @param row * @throws IOException ConflictException, HBase IOException. - * @throws NullPointException if oldLock is null (haven't read lock from - * HBase) + * @throws NullPointerException if oldLock is null (haven't read lock from HBase) */ @Override public void checkSingleRowLock(HaeinsaRowTransaction rowState, byte[] row) throws IOException { @@ -680,9 +661,10 @@ public void applyMutations(HaeinsaRowTransaction rowTxState, byte[] row) throws } break; } - default: + default: { break; } + } } } @@ -798,7 +780,7 @@ protected HTableInterface getHTable() { } /** - * Implementation of {@link HaeinsaReulstScanner} which is used when scan without transaction. + * Implementation of {@link HaeinsaResultScanner} which is used when scan without transaction. */ private class SimpleClientScanner implements HaeinsaResultScanner { private final ResultScanner scanner; @@ -879,29 +861,21 @@ private class ClientScanner implements HaeinsaResultScanner { private long maxSeqID = Long.MAX_VALUE; /** - * - * @param tx - * @param scanners - * @param familyMap * @param lockInclusive - whether scanners contains {@link TRowLock} inside. - * If not, should bring from {@link RowTransaction} or get from HBase directly. + * If not, should bring from {@link HaeinsaRowTransaction} or get from HBase directly. */ public ClientScanner(HaeinsaTransaction tx, Iterable scanners, - Map> familyMap, boolean lockInclusive) { + Map> familyMap, boolean lockInclusive) { this(tx, scanners, familyMap, null, lockInclusive); } /** - * - * @param tx - * @param scanners - * @param familyMap * @param intraScan - To support to use {@link ColumnRangeFilter} * @param lockInclusive - whether scanners contains {@link TRowLock} inside. - * If not, should bring from {@link RowTransaction} or get from HBase directly. + * If not, should bring from {@link HaeinsaRowTransaction} or get from HBase directly. */ public ClientScanner(HaeinsaTransaction tx, Iterable scanners, - Map> familyMap, HaeinsaIntraScan intraScan, boolean lockInclusive) { + Map> familyMap, HaeinsaIntraScan intraScan, boolean lockInclusive) { this.tx = tx; this.tableState = tx.createOrGetTableState(getTableName()); for (HaeinsaKeyValueScanner kvScanner : scanners) { @@ -924,11 +898,10 @@ public ClientScanner(HaeinsaTransaction tx, Iterable sca * Only can be called one time for every ClientScanner. *

* The reason why there are different variables for {@link #scannerList} and {@link #scanners} is that - * the way {@link #nextScanner()} implemented is removing {@link HaeinsaKeyValueScanner} one by one form scanners. + * the way {@link #nextScanner(HaeinsaKeyValueScanner)} implemented is removing + * {@link HaeinsaKeyValueScanner} one by one form scanners. * {@link #close()} method needs to close every {@link ClientScanner} when called, * so some other variable should preserve every scanner when ClientScanner created. - * - * @throws IOException */ private void initialize() throws IOException { try { @@ -990,7 +963,7 @@ public boolean hasNext() { } /** - * Return {@link TRowLock} for specific row from {@link IOException#scanners}. + * Return {@link TRowLock} for specific row from {@link #scanners}. * Return null if there is no proper {@link TRowLock}. *

* If one of these {@link #scanners} has row key which is smaller than given row, @@ -998,10 +971,8 @@ public boolean hasNext() { * So proper operation is guaranteed only when every scanner in {@link #scanners} return * smaller or equal row key when {@link HaeinsaKeyValueScanner#peek()} is called. * - * @param row * @return null if there is no TRowLock information inside scanners, - * return rowLock otherwise. - * @throws IOException + * return rowLock otherwise. */ private TRowLock peekLock(byte[] row) throws IOException { for (HaeinsaKeyValueScanner scanner : scanners) { @@ -1101,8 +1072,8 @@ public HaeinsaResult next() throws IOException { deleteTracker.add(currentKV, currentScanner.getSequenceID()); } else if (prevKV == currentKV || !(Bytes.equals(prevKV.getRow(), currentKV.getRow()) - && Bytes.equals(prevKV.getFamily(), currentKV.getFamily()) - && Bytes.equals(prevKV.getQualifier(), currentKV.getQualifier()))) { + && Bytes.equals(prevKV.getFamily(), currentKV.getFamily()) + && Bytes.equals(prevKV.getQualifier(), currentKV.getQualifier()))) { // if reference of prevKV and currentKV is same, the currentKV have new row. // Ignore when prevKV and currentKV is different but row, family, // qualifier of currentKv and prevKv is all same. (not likely) @@ -1143,9 +1114,6 @@ public HaeinsaResult next() throws IOException { * Moving index of scanner of currentScanner by one. If there is no more * element at the scanner, remove currentScanner from scanners * (NavigableSet) - * - * @param currentScanner - * @throws IOException */ private void nextScanner(HaeinsaKeyValueScanner currentScanner) throws IOException { scanners.remove(currentScanner); @@ -1301,8 +1269,8 @@ public void close() { * So {@link #peek()} method or {@link #next()} method will return value from same row. *

* HBaseGetScanner is now used in two cases. - * First, inside {@link HaeinsaTable#get()}, {@link HaeinsaKeyValue}s returned by this class will - * always have sequenceId of Long.MAX_VALUE. + * First, inside {@link HaeinsaTable#get(HaeinsaTransaction, HaeinsaGet)}, {@link HaeinsaKeyValue}s + * returned by this class will always have sequenceId of Long.MAX_VALUE. * Second is used inside {@link ClientScanner}. In this case, HBaseGetScanner recover failed transaction and * get recovered data from HBase. * Recovered {@link HaeinsaKeyValue} should have smaller sequenceId contained in ClientScanner so far @@ -1366,7 +1334,6 @@ public long getSequenceID() { } @Override - public void close() { - } + public void close() {} } } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIface.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIface.java index 81071d3..5f327c5 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIface.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIface.java @@ -61,12 +61,12 @@ public interface HaeinsaTableIface extends Closeable { * Extracts certain cells from a given row. * * @param tx HaeinsaTransaction which this operation is participated in. - * It can be null if user don't want to execute get inside transaction. + * It can be null if user don't want to execute get inside transaction. * @param get The object that specifies what data to fetch and from which row. * @return The data coming from the specified row, if it exists. If the row - * specified doesn't exist, the {@link HaeinsaResult} instance returned - * won't contain any {@link HaeinsaKeyValue}, as indicated by - * {@link HaeinsaResult#isEmpty()}. + * specified doesn't exist, the {@link HaeinsaResult} instance returned + * won't contain any {@link HaeinsaKeyValue}, as indicated by + * {@link HaeinsaResult#isEmpty()}. * @throws IOException if a remote or network exception occurs. */ HaeinsaResult get(@Nullable HaeinsaTransaction tx, HaeinsaGet get) throws IOException; @@ -76,7 +76,7 @@ public interface HaeinsaTableIface extends Closeable { * Similar with {@link HaeinsaTableIface#getScanner(HaeinsaTransaction, HaeinsaScan)}. * * @param tx HaeinsaTransaction which this operation is participated in. - * It can be null if user don't want to execute scan inside transaction. + * It can be null if user don't want to execute scan inside transaction. * @param family The column family to scan. * @return A scanner. * @throws IOException if a remote or network exception occurs. @@ -88,7 +88,7 @@ public interface HaeinsaTableIface extends Closeable { * Similar with {@link HaeinsaTableIface#getScanner(HaeinsaTransaction, HaeinsaScan)}. * * @param tx HaeinsaTransaction which this operation is participated in. - * It can be null if user don't want to execute scan inside transaction. + * It can be null if user don't want to execute scan inside transaction. * @param family The column family to scan. * @param qualifier The column qualifier to scan. * @return A scanner. @@ -102,7 +102,7 @@ HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, byte[] family, * object. * * @param tx HaeinsaTransaction which this operation is participated in. - It can be null if user don't want to execute scan inside transaction. + * It can be null if user don't want to execute scan inside transaction. * @param scan A configured {@link HaeinsaScan} object. * @return A scanner. * @throws IOException if a remote or network exception occurs. @@ -114,7 +114,7 @@ HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, byte[] family, * object. * * @param tx HaeinsaTransaction which this operation is participated in. - * It can be null if user don't want to execute scan inside transaction. + * It can be null if user don't want to execute scan inside transaction. * @param intraScan A configured {@link HaeinsaIntraScan} object. * @return A scanner. * @throws IOException if a remote or network exception occurs. @@ -168,5 +168,4 @@ HaeinsaResultScanner getScanner(@Nullable HaeinsaTransaction tx, byte[] family, */ @Override void close() throws IOException; - } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceFactory.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceFactory.java index b57a071..8936e4b 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceFactory.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceFactory.java @@ -35,8 +35,6 @@ public interface HaeinsaTableIfaceFactory { /** * Release the HaeinsaTable resource represented by the table. - * @param table */ void releaseHaeinsaTableIface(final HaeinsaTableIface table) throws IOException; - } diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceInternal.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceInternal.java index 7330498..ae9aa4d 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceInternal.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableIfaceInternal.java @@ -40,8 +40,6 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * If TRowLock is changed and checkAndPut failed, it means transaction is * failed so throw {@link ConflictException}. * - * @param rowState - * @param row * @throws IOException ConflictException, HBase IOException. */ void commitSingleRowPutOnly(HaeinsaRowTransaction rowState, byte[] row) throws IOException; @@ -51,11 +49,8 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * If TRowLock is changed, it means transaction is failed, so throw * {@link ConflictException}. * - * @param prevRowLock - * @param row * @throws IOException ConflictException, HBase IOException. - * @throws NullPointException if oldLock is null (haven't read lock from - * HBase) + * @throws NullPointerException if oldLock is null (haven't read lock from HBase) */ void checkSingleRowLock(HaeinsaRowTransaction rowState, byte[] row) throws IOException; @@ -65,16 +60,13 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * If first mutation in rowState is {@link HaeinsaPut}, then apply consequent Puts in the same RPC which changes lock to * {@link TRowLockState#PREWRITTEN}. * Remaining mutations which is not applied with first RPC is remained in {@link TRowLock#mutations}. - * This field will be used in {@link #applyMutations()} stage. + * This field will be used in {@link #applyMutations(HaeinsaRowTransaction, byte[])} stage. * Columns written in prewritten stage will be recorded in {@link TRowLock#prewritten} field, * which will be used in {@link HaeinsaTransaction#recover(boolean)} to clean up dirty data * if transaction failed. *

* Add list of secondary rows in secondaries field if this row is primary row, add key of primary row in primary field otherwise. * - * @param rowState - * @param row - * @param isPrimary * @throws IOException ConflictException, HBase IOException */ void prewrite(HaeinsaRowTransaction rowState, byte[] row, boolean isPrimary) throws IOException; @@ -93,8 +85,6 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * However this is not an issue for transaction consistency because new client will execute idempotent remove operations one more time * on same timestamp which are already used during previous transaction attempt. * - * @param rowTxState - * @param row * @throws IOException ConflictException, HBase IOException. */ void applyMutations(HaeinsaRowTransaction rowTxState, byte[] row) throws IOException; @@ -104,8 +94,6 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * Use commitTimestamp field of {@link TRowLock} as timestamp on HBase. * Only {@link TRowLock#version}, {@link TRowLock#state} and {@link TRowLock#commitTimestamp} fields are written. * - * @param tx - * @param row * @throws IOException ConflictException, HBase IOException. */ void makeStable(HaeinsaRowTransaction rowTxState, byte[] row) throws IOException; @@ -118,8 +106,6 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * failed-over client will call this method again to extend lock expiry on primary row. * In this case, {@link TRowLock} is remained in {@link TRowLockState#COMMITTED}. * - * @param tx - * @param row * @throws IOException ConflictException, HBase IOException. */ void commitPrimary(HaeinsaRowTransaction rowTxState, byte[] row) throws IOException; @@ -141,23 +127,19 @@ interface HaeinsaTableIfaceInternal extends HaeinsaTableIface { * or {@link TRowLockState#ABORTED} to another {@link TRowLockState#ABORTED}. * Later is when different client failed again during cleaning up aborted transaction. * - * @param tx - * @param row * @throws IOException ConflictException, HBase IOException. */ void abortPrimary(HaeinsaRowTransaction rowTxState, byte[] row) throws IOException; /** * Delete columns that are prewritten to the specific row during prewritten stage. + *

* Haeinsa can infer prewritten columns to clean up by parsing prewritten field in {@link TRowLock}. * Should remove column which have {@link TRowLock#currentTimestamp} as timestamp. - * This is possible by using {@link Delete#deleteColumn()} instead of {@link Delete#deleteColumns()}. *

- * Because Haeinsa uses {@link HTableInterface#checkAndDelete()} to delete prewrittens, + * Because Haeinsa uses {@link HTableInterface#checkAndDelete(byte[], byte[], byte[], byte[], Delete)} to delete prewrittens, * {@link TRowLock} is not changed. It will throw {@link ConflictException} if failed to acquire lock in checkAndDelete. * - * @param rowTxState - * @param row * @throws IOException ConflictException, HBase IOException. */ void deletePrewritten(HaeinsaRowTransaction rowTxState, byte[] row) throws IOException; diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTablePool.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTablePool.java index 64d7d11..0a5ec35 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTablePool.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTablePool.java @@ -79,7 +79,7 @@ public HaeinsaTablePool(final Configuration config, final int maxSize, final Hae * @param config configuration * @param maxSize maximum number of references to keep for each table * @param poolType pool type which is one of {@link PoolType#Reusable} or - * {@link PoolType#ThreadLocal} + * {@link PoolType#ThreadLocal} */ public HaeinsaTablePool(final Configuration config, final int maxSize, final PoolType poolType) { this(config, maxSize, null, poolType); @@ -96,10 +96,10 @@ public HaeinsaTablePool(final Configuration config, final int maxSize, final Poo * @param maxSize maximum number of references to keep for each table * @param tableFactory table factory * @param poolType pool type which is one of {@link PoolType#Reusable} or - * {@link PoolType#ThreadLocal} + * {@link PoolType#ThreadLocal} */ public HaeinsaTablePool(final Configuration config, final int maxSize, - final HaeinsaTableIfaceFactory tableFactory, PoolType poolType) { + final HaeinsaTableIfaceFactory tableFactory, PoolType poolType) { // Make a new configuration instance so I can safely cleanup when // done with the pool. this.config = config == null ? new Configuration() : config; @@ -110,13 +110,15 @@ public HaeinsaTablePool(final Configuration config, final int maxSize, } else { switch (poolType) { case Reusable: - case ThreadLocal: + case ThreadLocal: { this.poolType = poolType; break; - default: + } + default: { this.poolType = PoolType.Reusable; break; } + } } this.tables = new PoolMap(this.poolType, this.maxSize); } @@ -235,10 +237,8 @@ private void release(HaeinsaTableIface table) throws IOException { * table pool. *

* Note: this is a 'shutdown' of the given table pool and different from - * {@link #putTable(HaeinsaTableIface)}, that is used to return the table + * {@link #release(HaeinsaTableIface)}, that is used to return the table * instance to the pool for future re-use. - * - * @param tableName */ public void closeTablePool(final String tableName) throws IOException { Collection tables = this.tables.values(tableName); @@ -252,8 +252,6 @@ public void closeTablePool(final String tableName) throws IOException { /** * See {@link #closeTablePool(String)}. - * - * @param tableName */ public void closeTablePool(final byte[] tableName) throws IOException { closeTablePool(Bytes.toString(tableName)); diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableTransaction.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableTransaction.java index e1f08ea..2964958 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableTransaction.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTableTransaction.java @@ -18,6 +18,7 @@ import java.util.NavigableMap; import kr.co.vcnc.haeinsa.thrift.TRowLocks; +import kr.co.vcnc.haeinsa.thrift.generated.TRowLock; import org.apache.hadoop.hbase.util.Bytes; @@ -55,14 +56,13 @@ public HaeinsaTransaction getTransaction() { *

  • When get {@link HaeinsaRowTransaction} which is already contained in rowStates * - Should not change {@link HaeinsaRowTransaction#current} manually.
  • *
  • When rowTransaction is newly created by this method and {@link TRowLock} associated with the row exists - * - Use {@link HaeinsaRowTransaction#setCurrent()} to set current field of rowTransaction. + * - Use {@link HaeinsaRowTransaction#setCurrent(TRowLock)} to set current field of rowTransaction. *
  • When rowTransaction is newly created by this method and there is no associated {@link TRowLock}
  • - * - Use {@link TRowLocks#serialize(null)} method to set default {@link TRowLock} to current field of rowTransaction. + * - Use {@link TRowLocks#serialize(TRowLock)} method to set default {@link TRowLock} to current field of rowTransaction. * * - * @param row * @return RowTransaction - {@link HaeinsaRowTransaction} which contained in - * this instance. + * this instance. */ public HaeinsaRowTransaction createOrGetRowState(byte[] row) { HaeinsaRowTransaction rowState = rowStates.get(row); diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransaction.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransaction.java index ec4bfd9..5b2b072 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransaction.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransaction.java @@ -44,7 +44,7 @@ * and have reference to {@link HaeinsaTransactionManager} which created this instance. *

    * HaeinsaTransaction can be generated via calling {@link HaeinsaTransactionManager#begin()} - * or {@link HaeinsaTransactionManager#getTransaction()}. + * or {@link HaeinsaTransactionManager#getTransaction(byte[], byte[])}. * Former is used when start new transaction, later is used when try to roll back or retry failed transaction. *

    * One {@link HaeinsaTransaction} can't be used after calling {@link #commit()} or {@link #rollback()} is called. @@ -166,9 +166,8 @@ HaeinsaTransactionLocals getLocals() { /** * Bring {@link HaeinsaTableTransaction} which have name of tableName. * If there is no {@link HaeinsaTableTransaction} have this name, - * then create one instance for it and save inside {@link #tableStates} and return. + * then create one instance for it and save inside {@link #txStates} and return. * - * @param tableName * @return instance of {@link HaeinsaTableTransaction} */ protected HaeinsaTableTransaction createOrGetTableState(byte[] tableName) { @@ -266,13 +265,14 @@ public void commit() throws IOException { case NOTHING: { break; } - default: + default: { break; } + } } /** - * Use {@link HaeinsaTable#checkSingleRowLock()} to check RowLock on HBase + * Use {@link HaeinsaTable#checkSingleRowLock(HaeinsaRowTransaction, byte[])} to check RowLock on HBase * of read-only rows of tx. If all lock-checking by get was success, * read-only tx was success. Throws ConflictException otherwise. * @@ -309,8 +309,6 @@ private void commitReadOnly() throws IOException { /** * Commit single row & PUT only (possibly include get/scan, but not Delete) * Transaction. - * - * @throws IOException */ private void commitSingleRowPutOnly() throws IOException { HaeinsaTableTransaction primaryTableState = createOrGetTableState(primary.getTableName()); @@ -373,7 +371,7 @@ private void commitMultiRowsMutation() throws IOException { * 1. In case of {@link #commitMultiRowsMutation()}, after changing primary row to * {@link TRowLockState#COMMITTED} and applying all mutations in primary row and secondary rows. *

    - * 2. When try to {@link #recover()} failed transaction in the middle of execution. + * 2. When try to {@link #recover(boolean)} failed transaction in the middle of execution. * This method should be called only when primary row is in the state of {@link TRowLockState#COMMITTED}. * * @throws IOException ConflictException, HBase IOException. @@ -419,12 +417,11 @@ private void makeStable() throws IOException { } /** - * Reload information of failed transaction and complete it by calling {@link #makStable()} + * Reload information of failed transaction and complete it by calling {@link #makeStable()} * if already completed one, ( when primaryRow have {@link TRowLockState#COMMITTED} state } * or abort by calling {@link #abort()} otherwise. * * @param ignoreExpiry ignore row lock's expiry - * @throws IOException */ protected void recover(boolean ignoreExpiry) throws IOException { boolean onRecovery = true; @@ -470,7 +467,7 @@ protected void recover(boolean ignoreExpiry) throws IOException { *

    * Aborting is executed by following order. *

      - *
    1. Abort primary row by calling {@link HaeinsaTableIfaceInternal#abortPrimary()}.
    2. + *
    3. Abort primary row by calling {@link HaeinsaTableIfaceInternal#abortPrimary(HaeinsaRowTransaction, byte[])}.
    4. *
    5. Visit all secondary rows and change from prewritten to stable state. * Prewritten data on rows are removed at this state.
    6. *
    7. Change primary row to stable state.
    8. @@ -515,6 +512,7 @@ protected void abort() throws IOException { /** * for unit test code + * * @param onRecovery onRecovery */ void classifyAndSortRows(boolean onRecovery) { @@ -546,7 +544,7 @@ public NavigableMap getTableStates() { * This method returns false only if there is no changes on data in the transaction. * * @return true if one or more row state has mutation, - * false if any row does not contains mutation. + * false if any row does not contains mutation. */ public boolean hasChanges() { for (HaeinsaTableTransaction tableState : tableStates.values()) { @@ -566,8 +564,6 @@ public boolean hasChanges() { *

      * Transaction of single row with at least one of {@link HaeinsaDelete} * will be considered as {@link CommitMethod#MULTI_ROW_MUTATIONS}. - * - * @return */ public CommitMethod determineCommitMethod() { int count = 0; @@ -606,8 +602,6 @@ public CommitMethod determineCommitMethod() { /** * Return mutation rows which is hash-sorted by TRowKey(table, row). - * - * @return */ public NavigableMap getMutationRowStates() { Preconditions.checkNotNull(mutationRowStates, "Should call classifyAndSortRows first."); @@ -616,8 +610,6 @@ public NavigableMap getMutationRowStates() { /** * Return read-only rows which is hash-sorted by TRowKey(table, row). - * - * @return */ public NavigableMap getReadOnlyRowStates() { Preconditions.checkNotNull(readOnlyRowStates, "Should call classifyAndSortRows first."); diff --git a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransactionManager.java b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransactionManager.java index dbfbafe..ac927fb 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransactionManager.java +++ b/src/main/java/kr/co/vcnc/haeinsa/HaeinsaTransactionManager.java @@ -70,8 +70,7 @@ public HaeinsaTransaction begin() { * @param tableName TableName of Transaction to recover. * @param row Row of Transaction to recover. * @return Transaction instance if there is any ongoing Transaction on row, - * return null otherwise. - * @throws IOException + * return null otherwise. */ @Nullable protected HaeinsaTransaction getTransaction(byte[] tableName, byte[] row) throws IOException { @@ -108,7 +107,7 @@ protected HaeinsaTransaction getTransaction(byte[] tableName, byte[] row) throws * @param tableName Table name of the row * @param row Row key of the row * @return null if TRowLock is {@link TRowLockState#STABLE}, otherwise - * return rowLock from HBase. + * return rowLock from HBase. * @throws IOException When error occurs in HBase. */ private TRowLock getUnstableRowLock(byte[] tableName, byte[] row) throws IOException { @@ -146,7 +145,7 @@ private TRowLock getRowLock(byte[] tableName, byte[] row) throws IOException { * @param row Row of Transaction to check dangling RowLock. * @param rowLock RowLock to check if it is dangling * @throws IOException When error occurs. Especially throw - * {@link DanglingRowLockException}if given RowLock is dangling. + * {@link DanglingRowLockException}if given RowLock is dangling. */ private void checkDanglingRowLockOrThrow(byte[] tableName, byte[] row, TRowLock rowLock) throws IOException { TRowLock previousRowLock = rowLock; @@ -168,13 +167,9 @@ private void checkDanglingRowLockOrThrow(byte[] tableName, byte[] row, TRowLock /** * Recover TRowLocks of failed HaeinsaTransaction from primary row on HBase. - * Transaction information about secondary rows are recovered with {@link #addSecondaryRowLock()}. + * Transaction information about secondary rows are recovered with + * {@link #addSecondaryRowLock(HaeinsaTransaction, TRowKey, TRowLock, TRowKey)}. * HaeinsaTransaction made by this method do not assign proper values on mutations variable. - * - * @param rowKey - * @param primaryRowLock - * @return - * @throws IOException */ private HaeinsaTransaction getTransactionFromPrimary(TRowKey rowKey, TRowLock primaryRowLock) throws IOException { HaeinsaTransaction transaction = new HaeinsaTransaction(this); @@ -200,15 +195,11 @@ private HaeinsaTransaction getTransactionFromPrimary(TRowKey rowKey, TRowLock pr * Secondary row is not included in recovered transaction neither when commitTimestamp is different with primary row's, * because it implicates that the row is locked by other transaction. *

      - * As similar to {@link #getTransactionFromPrimary()}, rowTransaction added by this method do not have + * As similar to {@link #getTransactionFromPrimary(TRowKey, TRowLock)}, rowTransaction added by this method do not have * proper mutations variable. - * - * @param transaction - * @param rowKey - * @throws IOException */ private void addSecondaryRowLock(HaeinsaTransaction transaction, TRowKey primaryRowKey, - TRowLock primaryRowLock, TRowKey secondaryRowKey) throws IOException { + TRowLock primaryRowLock, TRowKey secondaryRowKey) throws IOException { TRowLock secondaryRowLock = getRowLock(secondaryRowKey.getTableName(), secondaryRowKey.getRow()); if (secondaryRowLock.getCommitTimestamp() > transaction.getCommitTimestamp()) { // this row isn't a part of this transaction or already aborted. diff --git a/src/main/java/kr/co/vcnc/haeinsa/exception/ConflictException.java b/src/main/java/kr/co/vcnc/haeinsa/exception/ConflictException.java index 7164451..2ece88e 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/exception/ConflictException.java +++ b/src/main/java/kr/co/vcnc/haeinsa/exception/ConflictException.java @@ -23,7 +23,6 @@ * explicitly distinguish between failure on HBase IO and conflict. */ public class ConflictException extends IOException { - private static final long serialVersionUID = -6181950952954013762L; public ConflictException() { diff --git a/src/main/java/kr/co/vcnc/haeinsa/exception/DanglingRowLockException.java b/src/main/java/kr/co/vcnc/haeinsa/exception/DanglingRowLockException.java index d2ef570..0d7f736 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/exception/DanglingRowLockException.java +++ b/src/main/java/kr/co/vcnc/haeinsa/exception/DanglingRowLockException.java @@ -27,7 +27,6 @@ * exception if there is fatal consistency error in Haeinsa. */ public class DanglingRowLockException extends ConflictException { - private static final long serialVersionUID = -9220580990865263679L; private final TRowKey danglingRowKey; @@ -51,5 +50,4 @@ public DanglingRowLockException(TRowKey danglingRowKey, String message) { public TRowKey getDanglingRowKey() { return danglingRowKey; } - } diff --git a/src/main/java/kr/co/vcnc/haeinsa/exception/NotExpiredYetException.java b/src/main/java/kr/co/vcnc/haeinsa/exception/NotExpiredYetException.java index 34ce270..53aeedf 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/exception/NotExpiredYetException.java +++ b/src/main/java/kr/co/vcnc/haeinsa/exception/NotExpiredYetException.java @@ -20,11 +20,9 @@ * This exception extends {@link ConflictException} */ public class NotExpiredYetException extends ConflictException { - private static final long serialVersionUID = -5160271558362505568L; - public NotExpiredYetException() { - } + public NotExpiredYetException() {} public NotExpiredYetException(String message) { super(message); diff --git a/src/main/java/kr/co/vcnc/haeinsa/exception/RecoverableConflictException.java b/src/main/java/kr/co/vcnc/haeinsa/exception/RecoverableConflictException.java index c77fd08..e516724 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/exception/RecoverableConflictException.java +++ b/src/main/java/kr/co/vcnc/haeinsa/exception/RecoverableConflictException.java @@ -22,11 +22,9 @@ * because this occurs on failure of write by other transaction. */ public class RecoverableConflictException extends ConflictException { - private static final long serialVersionUID = 3720142235607540830L; - public RecoverableConflictException() { - } + public RecoverableConflictException() {} public RecoverableConflictException(String message) { super(message); diff --git a/src/main/java/kr/co/vcnc/haeinsa/thrift/TRowLocks.java b/src/main/java/kr/co/vcnc/haeinsa/thrift/TRowLocks.java index 507d94d..9f8816a 100644 --- a/src/main/java/kr/co/vcnc/haeinsa/thrift/TRowLocks.java +++ b/src/main/java/kr/co/vcnc/haeinsa/thrift/TRowLocks.java @@ -37,6 +37,8 @@ * TRowLock(commitTimestamp = Long.MIN_VALUE) <=> byte[] null */ public final class TRowLocks { + private TRowLocks() {} + private static final TProtocolFactory PROTOCOL_FACTORY = new TCompactProtocol.Factory(); private static TSerializer createSerializer() { @@ -47,9 +49,6 @@ private static TDeserializer createDeserializer() { return new TDeserializer(PROTOCOL_FACTORY); } - private TRowLocks() { - } - public static TRowLock deserialize(byte[] rowLockBytes) throws IOException { if (rowLockBytes == null) { return new TRowLock(ROW_LOCK_VERSION, TRowLockState.STABLE, Long.MIN_VALUE); diff --git a/src/test/java/kr/co/vcnc/haeinsa/Haeinsa67BugTest.java b/src/test/java/kr/co/vcnc/haeinsa/Haeinsa67BugTest.java index 93fe37d..32ff3b4 100644 --- a/src/test/java/kr/co/vcnc/haeinsa/Haeinsa67BugTest.java +++ b/src/test/java/kr/co/vcnc/haeinsa/Haeinsa67BugTest.java @@ -46,8 +46,8 @@ public void testRecover() throws Exception { TRowKey secondaryRowKey = new TRowKey().setTableName(testTable.getTableName()).setRow(Bytes.toBytes("Brad")); TRowLock secondaryRowLock = new TRowLock(HaeinsaConstants.ROW_LOCK_VERSION, TRowLockState.STABLE, 1380504156137L); TRowLock primaryRowLock = new TRowLock(HaeinsaConstants.ROW_LOCK_VERSION, TRowLockState.PREWRITTEN, 1380504157100L) - .setCurrentTimestamp(1380504156000L) - .setExpiry(1380504160000L); + .setCurrentTimestamp(1380504156000L) + .setExpiry(1380504160000L); primaryRowLock.addToSecondaries(secondaryRowKey); Put primaryPut = new Put(primaryRowKey.getRow()); primaryPut.add(HaeinsaConstants.LOCK_FAMILY, HaeinsaConstants.LOCK_QUALIFIER, diff --git a/src/test/java/kr/co/vcnc/haeinsa/HaeinsaUnitTest.java b/src/test/java/kr/co/vcnc/haeinsa/HaeinsaUnitTest.java index 9a8976f..ab1561d 100644 --- a/src/test/java/kr/co/vcnc/haeinsa/HaeinsaUnitTest.java +++ b/src/test/java/kr/co/vcnc/haeinsa/HaeinsaUnitTest.java @@ -580,8 +580,6 @@ public void testConflictAndRecover() throws Exception { /** * Unit test for multiple mutations for any rows in {@link HaeinsaTransaction}. - * - * @throws Exception */ @Test public void testMultipleMutations() throws Exception { @@ -669,8 +667,6 @@ public void testMultipleMutations() throws Exception { /** * Unit test for check get/scan without transaction. - * - * @throws Exception */ @Test public void testHaeinsaTableWithoutTx() throws Exception {