HBASE-20069 fix existing findbugs errors in hbase-server

This commit is contained in:
Michael Stack 2018-02-24 13:01:02 -08:00
parent a312705dbc
commit 44544c7db0
16 changed files with 147 additions and 84 deletions

View File

@ -228,6 +228,7 @@ public class EncodedDataBlock {
*/ */
public byte[] encodeData() { public byte[] encodeData() {
ByteArrayOutputStream baos = new ByteArrayOutputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte [] baosBytes = null;
try { try {
baos.write(HConstants.HFILEBLOCK_DUMMY_HEADER); baos.write(HConstants.HFILEBLOCK_DUMMY_HEADER);
DataOutputStream out = new DataOutputStream(baos); DataOutputStream out = new DataOutputStream(baos);
@ -255,25 +256,17 @@ public class EncodedDataBlock {
kv.setSequenceId(memstoreTS); kv.setSequenceId(memstoreTS);
this.dataBlockEncoder.encode(kv, encodingCtx, out); this.dataBlockEncoder.encode(kv, encodingCtx, out);
} }
BufferGrabbingByteArrayOutputStream stream = new BufferGrabbingByteArrayOutputStream(); // Below depends on BAOS internal behavior. toByteArray makes a copy of bytes so far.
baos.writeTo(stream); baos.flush();
this.dataBlockEncoder.endBlockEncoding(encodingCtx, out, stream.ourBytes); baosBytes = baos.toByteArray();
this.dataBlockEncoder.endBlockEncoding(encodingCtx, out, baosBytes);
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException(String.format( throw new RuntimeException(String.format(
"Bug in encoding part of algorithm %s. " + "Bug in encoding part of algorithm %s. " +
"Probably it requested more bytes than are available.", "Probably it requested more bytes than are available.",
toString()), e); toString()), e);
} }
return baos.toByteArray(); return baosBytes;
}
private static class BufferGrabbingByteArrayOutputStream extends ByteArrayOutputStream {
private byte[] ourBytes;
@Override
public synchronized void write(byte[] b, int off, int len) {
this.ourBytes = b;
}
} }
@Override @Override

View File

@ -282,7 +282,7 @@ public class MultiByteBuff extends ByteBuff {
return ByteBufferUtils.toShort(item, offsetInItem); return ByteBufferUtils.toShort(item, offsetInItem);
} }
if (items.length - 1 == itemIndex) { if (items.length - 1 == itemIndex) {
// means cur item is the last one and we wont be able to read a int. Throw exception // means cur item is the last one and we wont be able to read a short. Throw exception
throw new BufferUnderflowException(); throw new BufferUnderflowException();
} }
ByteBuffer nextItem = items[itemIndex + 1]; ByteBuffer nextItem = items[itemIndex + 1];
@ -294,7 +294,7 @@ public class MultiByteBuff extends ByteBuff {
} }
for (int i = 0; i < Bytes.SIZEOF_SHORT - remainingLen; i++) { for (int i = 0; i < Bytes.SIZEOF_SHORT - remainingLen; i++) {
l = (short) (l << 8); l = (short) (l << 8);
l = (short) (l ^ (ByteBufferUtils.toByte(item, i) & 0xFF)); l = (short) (l ^ (ByteBufferUtils.toByte(nextItem, i) & 0xFF));
} }
return l; return l;
} }

View File

@ -43,6 +43,25 @@ public class TestMultiByteBuff {
public static final HBaseClassTestRule CLASS_RULE = public static final HBaseClassTestRule CLASS_RULE =
HBaseClassTestRule.forClass(TestMultiByteBuff.class); HBaseClassTestRule.forClass(TestMultiByteBuff.class);
/**
* Test right answer though we span many sub-buffers.
*/
@Test
public void testGetShort() {
ByteBuffer bb1 = ByteBuffer.allocate(1);
bb1.put((byte)1);
ByteBuffer bb2 = ByteBuffer.allocate(1);
bb2.put((byte)0);
ByteBuffer bb3 = ByteBuffer.allocate(1);
bb3.put((byte)2);
ByteBuffer bb4 = ByteBuffer.allocate(1);
bb4.put((byte)3);
MultiByteBuff mbb = new MultiByteBuff(bb1, bb2, bb3, bb4);
assertEquals(256, mbb.getShortAfterPosition(0));
assertEquals(2, mbb.getShortAfterPosition(1));
assertEquals(515, mbb.getShortAfterPosition(2));
}
@Test @Test
public void testWritesAndReads() { public void testWritesAndReads() {
// Absolute reads // Absolute reads

View File

@ -206,7 +206,6 @@ public class ProcedureExecutor<TEnvironment> {
final long now = EnvironmentEdgeManager.currentTime(); final long now = EnvironmentEdgeManager.currentTime();
final Iterator<Map.Entry<Long, CompletedProcedureRetainer>> it = completed.entrySet().iterator(); final Iterator<Map.Entry<Long, CompletedProcedureRetainer>> it = completed.entrySet().iterator();
final boolean debugEnabled = LOG.isDebugEnabled();
while (it.hasNext() && store.isRunning()) { while (it.hasNext() && store.isRunning()) {
final Map.Entry<Long, CompletedProcedureRetainer> entry = it.next(); final Map.Entry<Long, CompletedProcedureRetainer> entry = it.next();
final CompletedProcedureRetainer retainer = entry.getValue(); final CompletedProcedureRetainer retainer = entry.getValue();

View File

@ -209,7 +209,6 @@ public abstract class StateMachineProcedure<TEnvironment, TState>
@Override @Override
protected boolean abort(final TEnvironment env) { protected boolean abort(final TEnvironment env) {
final TState state = getCurrentState();
LOG.debug("Abort requested for {}", this); LOG.debug("Abort requested for {}", this);
if (hasMoreState()) { if (hasMoreState()) {
aborted.set(true); aborted.set(true);

View File

@ -114,6 +114,9 @@ public abstract class RpcServer implements RpcServerInterface,
+ Server.class.getName()); + Server.class.getName());
protected SecretManager<TokenIdentifier> secretManager; protected SecretManager<TokenIdentifier> secretManager;
protected final Map<String, String> saslProps; protected final Map<String, String> saslProps;
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="IS2_INCONSISTENT_SYNC",
justification="Start is synchronized so authManager creation is single-threaded")
protected ServiceAuthorizationManager authManager; protected ServiceAuthorizationManager authManager;
/** This is set to Call object before Handler invokes an RPC and ybdie /** This is set to Call object before Handler invokes an RPC and ybdie

View File

@ -171,7 +171,6 @@ import org.apache.hadoop.hbase.util.Addressing;
import org.apache.hadoop.hbase.util.Bytes; import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.hbase.util.CompressionTest; import org.apache.hadoop.hbase.util.CompressionTest;
import org.apache.hadoop.hbase.util.EncryptionTest; import org.apache.hadoop.hbase.util.EncryptionTest;
import org.apache.hadoop.hbase.util.FSUtils;
import org.apache.hadoop.hbase.util.HFileArchiveUtil; import org.apache.hadoop.hbase.util.HFileArchiveUtil;
import org.apache.hadoop.hbase.util.HasThread; import org.apache.hadoop.hbase.util.HasThread;
import org.apache.hadoop.hbase.util.IdLock; import org.apache.hadoop.hbase.util.IdLock;
@ -1207,8 +1206,6 @@ public class HMaster extends HRegionServer implements MasterServices {
private void startProcedureExecutor() throws IOException { private void startProcedureExecutor() throws IOException {
final MasterProcedureEnv procEnv = new MasterProcedureEnv(this); final MasterProcedureEnv procEnv = new MasterProcedureEnv(this);
final Path rootDir = FSUtils.getRootDir(conf);
procedureStore = new WALProcedureStore(conf, procedureStore = new WALProcedureStore(conf,
new MasterProcedureEnv.WALStoreLeaseRecovery(this)); new MasterProcedureEnv.WALStoreLeaseRecovery(this));
procedureStore.registerListener(new MasterProcedureEnv.MasterProcedureStoreListener(this)); procedureStore.registerListener(new MasterProcedureEnv.MasterProcedureStoreListener(this));

View File

@ -1298,7 +1298,6 @@ public class AssignmentManager implements ServerListener {
final Set<ServerName> offlineServersWithOnlineRegions = new HashSet<>(); final Set<ServerName> offlineServersWithOnlineRegions = new HashSet<>();
int size = regionStates.getRegionStateNodes().size(); int size = regionStates.getRegionStateNodes().size();
final List<RegionInfo> offlineRegionsToAssign = new ArrayList<>(size); final List<RegionInfo> offlineRegionsToAssign = new ArrayList<>(size);
long startTime = System.currentTimeMillis();
// If deadservers then its a failover, else, we are not sure yet. // If deadservers then its a failover, else, we are not sure yet.
boolean failover = deadServers; boolean failover = deadServers;
for (RegionStateNode regionNode: regionStates.getRegionStateNodes()) { for (RegionStateNode regionNode: regionStates.getRegionStateNodes()) {

View File

@ -432,6 +432,10 @@ public class SplitTableRegionProcedure
} }
RegionInfo parentHRI = node.getRegionInfo(); RegionInfo parentHRI = node.getRegionInfo();
if (parentHRI == null) {
LOG.info("Unsplittable; parent region is null; node={}", node);
return false;
}
// Lookup the parent HRI state from the AM, which has the latest updated info. // Lookup the parent HRI state from the AM, which has the latest updated info.
// Protect against the case where concurrent SPLIT requests came in and succeeded // Protect against the case where concurrent SPLIT requests came in and succeeded
// just before us. // just before us.
@ -457,8 +461,7 @@ public class SplitTableRegionProcedure
// we are always able to split the region // we are always able to split the region
if (!env.getMasterServices().isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) { if (!env.getMasterServices().isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {
LOG.warn("pid=" + getProcId() + " split switch is off! skip split of " + parentHRI); LOG.warn("pid=" + getProcId() + " split switch is off! skip split of " + parentHRI);
setFailure(new IOException("Split region " + setFailure(new IOException("Split region " + parentHRI.getRegionNameAsString() +
(parentHRI == null? "null": parentHRI.getRegionNameAsString()) +
" failed due to split switch off")); " failed due to split switch off"));
return false; return false;
} }

View File

@ -50,6 +50,8 @@ import org.slf4j.LoggerFactory;
* Abstract Cleaner that uses a chain of delegates to clean a directory of files * Abstract Cleaner that uses a chain of delegates to clean a directory of files
* @param <T> Cleaner delegate class that is dynamically loaded from configuration * @param <T> Cleaner delegate class that is dynamically loaded from configuration
*/ */
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="ST_WRITE_TO_STATIC_FROM_INSTANCE_METHOD",
justification="TODO: Fix. It is wonky have static pool initialized from instance")
public abstract class CleanerChore<T extends FileCleanerDelegate> extends ScheduledChore public abstract class CleanerChore<T extends FileCleanerDelegate> extends ScheduledChore
implements ConfigurationObserver { implements ConfigurationObserver {
@ -67,8 +69,8 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
// It may be waste resources for each cleaner chore own its pool, // It may be waste resources for each cleaner chore own its pool,
// so let's make pool for all cleaner chores. // so let's make pool for all cleaner chores.
private static volatile ForkJoinPool chorePool; private static volatile ForkJoinPool CHOREPOOL;
private static volatile int chorePoolSize; private static volatile int CHOREPOOLSIZE;
protected final FileSystem fs; protected final FileSystem fs;
private final Path oldFileDir; private final Path oldFileDir;
@ -102,15 +104,14 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
this.params = params; this.params = params;
initCleanerChain(confKey); initCleanerChain(confKey);
if (chorePool == null) { if (CHOREPOOL == null) {
String poolSize = conf.get(CHORE_POOL_SIZE, DEFAULT_CHORE_POOL_SIZE); String poolSize = conf.get(CHORE_POOL_SIZE, DEFAULT_CHORE_POOL_SIZE);
chorePoolSize = calculatePoolSize(poolSize); CHOREPOOLSIZE = calculatePoolSize(poolSize);
// poolSize may be 0 or 0.0 from a careless configuration, // poolSize may be 0 or 0.0 from a careless configuration,
// double check to make sure. // double check to make sure.
chorePoolSize = chorePoolSize == 0 ? CHOREPOOLSIZE = CHOREPOOLSIZE == 0? calculatePoolSize(DEFAULT_CHORE_POOL_SIZE): CHOREPOOLSIZE;
calculatePoolSize(DEFAULT_CHORE_POOL_SIZE) : chorePoolSize; this.CHOREPOOL = new ForkJoinPool(CHOREPOOLSIZE);
this.chorePool = new ForkJoinPool(chorePoolSize); LOG.info("Cleaner pool size is {}", CHOREPOOLSIZE);
LOG.info("Cleaner pool size is {}", chorePoolSize);
} }
} }
@ -119,11 +120,11 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
* @param poolSize size from configuration * @param poolSize size from configuration
* @return size of pool after calculation * @return size of pool after calculation
*/ */
int calculatePoolSize(String poolSize) { static int calculatePoolSize(String poolSize) {
if (poolSize.matches("[1-9][0-9]*")) { if (poolSize.matches("[1-9][0-9]*")) {
// If poolSize is an integer, return it directly, // If poolSize is an integer, return it directly,
// but upmost to the number of available processors. // but upmost to the number of available processors.
int size = Math.min(Integer.valueOf(poolSize), AVAIL_PROCESSORS); int size = Math.min(Integer.parseInt(poolSize), AVAIL_PROCESSORS);
if (size == AVAIL_PROCESSORS) { if (size == AVAIL_PROCESSORS) {
LOG.warn("Use full core processors to scan dir, size={}", size); LOG.warn("Use full core processors to scan dir, size={}", size);
} }
@ -173,12 +174,12 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
@Override @Override
public void onConfigurationChange(Configuration conf) { public void onConfigurationChange(Configuration conf) {
int updatedSize = calculatePoolSize(conf.get(CHORE_POOL_SIZE, DEFAULT_CHORE_POOL_SIZE)); int updatedSize = calculatePoolSize(conf.get(CHORE_POOL_SIZE, DEFAULT_CHORE_POOL_SIZE));
if (updatedSize == chorePoolSize) { if (updatedSize == CHOREPOOLSIZE) {
LOG.trace("Size from configuration is same as previous={}, no need to update.", updatedSize); LOG.trace("Size from configuration is same as previous={}, no need to update.", updatedSize);
return; return;
} }
chorePoolSize = updatedSize; CHOREPOOLSIZE = updatedSize;
if (chorePool.getPoolSize() == 0) { if (CHOREPOOL.getPoolSize() == 0) {
// Chore does not work now, update it directly. // Chore does not work now, update it directly.
updateChorePoolSize(updatedSize); updateChorePoolSize(updatedSize);
return; return;
@ -188,9 +189,9 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
} }
private void updateChorePoolSize(int updatedSize) { private void updateChorePoolSize(int updatedSize) {
chorePool.shutdownNow(); CHOREPOOL.shutdownNow();
LOG.info("Update chore's pool size from {} to {}", chorePool.getParallelism(), updatedSize); LOG.info("Update chore's pool size from {} to {}", CHOREPOOL.getParallelism(), updatedSize);
chorePool = new ForkJoinPool(updatedSize); CHOREPOOL = new ForkJoinPool(updatedSize);
} }
/** /**
@ -226,7 +227,7 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
} }
// After each clean chore, checks if receives reconfigure notification while cleaning // After each clean chore, checks if receives reconfigure notification while cleaning
if (reconfig.compareAndSet(true, false)) { if (reconfig.compareAndSet(true, false)) {
updateChorePoolSize(chorePoolSize); updateChorePoolSize(CHOREPOOLSIZE);
} }
} else { } else {
LOG.debug("Cleaner chore disabled! Not cleaning."); LOG.debug("Cleaner chore disabled! Not cleaning.");
@ -240,7 +241,7 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
public Boolean runCleaner() { public Boolean runCleaner() {
preRunCleaner(); preRunCleaner();
CleanerTask task = new CleanerTask(this.oldFileDir, true); CleanerTask task = new CleanerTask(this.oldFileDir, true);
chorePool.submit(task); CHOREPOOL.submit(task);
return task.join(); return task.join();
} }
@ -372,7 +373,7 @@ public abstract class CleanerChore<T extends FileCleanerDelegate> extends Schedu
@VisibleForTesting @VisibleForTesting
int getChorePoolSize() { int getChorePoolSize() {
return chorePoolSize; return CHOREPOOLSIZE;
} }
/** /**

View File

@ -8111,13 +8111,12 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
} }
@Override @Override
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="SF_SWITCH_FALLTHROUGH",
justification="Intentional")
public void startRegionOperation(Operation op) throws IOException { public void startRegionOperation(Operation op) throws IOException {
switch (op) { switch (op) {
case GET: // read operations case GET: // read operations
case SCAN: case SCAN:
checkReadsEnabled(); checkReadsEnabled();
break;
default: default:
break; break;
} }

View File

@ -89,6 +89,40 @@ class MemStoreFlusher implements FlushRequester {
private FlushType flushType; private FlushType flushType;
/**
* Singleton instance of this class inserted into flush queue.
*/
private static final WakeupFlushThread WAKEUPFLUSH_INSTANCE = new WakeupFlushThread();
/**
* Marker class used as a token inserted into flush queue that ensures the flusher does not sleep.
* Create a single instance only.
*/
private static final class WakeupFlushThread implements FlushQueueEntry {
private WakeupFlushThread() {}
@Override
public long getDelay(TimeUnit unit) {
return 0;
}
@Override
public int compareTo(Delayed o) {
return -1;
}
@Override
public boolean equals(Object obj) {
return obj == this;
}
@Override
public int hashCode() {
return 42;
}
}
/** /**
* @param conf * @param conf
* @param server * @param server
@ -147,17 +181,18 @@ class MemStoreFlusher implements FlushRequester {
boolean flushedOne = false; boolean flushedOne = false;
while (!flushedOne) { while (!flushedOne) {
// Find the biggest region that doesn't have too many storefiles // Find the biggest region that doesn't have too many storefiles (might be null!)
// (might be null!) HRegion bestFlushableRegion =
HRegion bestFlushableRegion = getBiggestMemStoreRegion(regionsBySize, excludedRegions, true); getBiggestMemStoreRegion(regionsBySize, excludedRegions, true);
// Find the biggest region, total, even if it might have too many flushes. // Find the biggest region, total, even if it might have too many flushes.
HRegion bestAnyRegion = getBiggestMemStoreRegion( HRegion bestAnyRegion = getBiggestMemStoreRegion(regionsBySize, excludedRegions, false);
regionsBySize, excludedRegions, false);
// Find the biggest region that is a secondary region // Find the biggest region that is a secondary region
HRegion bestRegionReplica = getBiggestMemStoreOfRegionReplica(regionsBySize, HRegion bestRegionReplica = getBiggestMemStoreOfRegionReplica(regionsBySize, excludedRegions);
excludedRegions); if (bestAnyRegion == null) {
// If bestAnyRegion is null, assign replica. It may be null too. Next step is check for null
if (bestAnyRegion == null && bestRegionReplica == null) { bestAnyRegion = bestRegionReplica;
}
if (bestAnyRegion == null) {
LOG.error("Above memory mark but there are no flushable regions!"); LOG.error("Above memory mark but there are no flushable regions!");
return false; return false;
} }
@ -169,19 +204,20 @@ class MemStoreFlusher implements FlushRequester {
case ABOVE_OFFHEAP_HIGHER_MARK: case ABOVE_OFFHEAP_HIGHER_MARK:
case ABOVE_OFFHEAP_LOWER_MARK: case ABOVE_OFFHEAP_LOWER_MARK:
bestAnyRegionSize = bestAnyRegion.getMemStoreOffHeapSize(); bestAnyRegionSize = bestAnyRegion.getMemStoreOffHeapSize();
bestFlushableRegionSize = bestFlushableRegion.getMemStoreOffHeapSize(); bestFlushableRegionSize = getMemStoreOffHeapSize(bestFlushableRegion);
break; break;
case ABOVE_ONHEAP_HIGHER_MARK: case ABOVE_ONHEAP_HIGHER_MARK:
case ABOVE_ONHEAP_LOWER_MARK: case ABOVE_ONHEAP_LOWER_MARK:
bestAnyRegionSize = bestAnyRegion.getMemStoreHeapSize(); bestAnyRegionSize = bestAnyRegion.getMemStoreHeapSize();
bestFlushableRegionSize = bestFlushableRegion.getMemStoreHeapSize(); bestFlushableRegionSize = getMemStoreHeapSize(bestFlushableRegion);
break; break;
default: default:
bestAnyRegionSize = bestAnyRegion.getMemStoreDataSize(); bestAnyRegionSize = bestAnyRegion.getMemStoreDataSize();
bestFlushableRegionSize = bestFlushableRegion.getMemStoreDataSize(); bestFlushableRegionSize = getMemStoreDataSize(bestFlushableRegion);
} }
if (bestFlushableRegion != null && if (bestAnyRegionSize > 2 * bestFlushableRegionSize) {
bestAnyRegionSize > 2 * bestFlushableRegionSize) {
// Even if it's not supposed to be flushed, pick a region if it's more than twice // Even if it's not supposed to be flushed, pick a region if it's more than twice
// as big as the best flushable one - otherwise when we're under pressure we make // as big as the best flushable one - otherwise when we're under pressure we make
// lots of little flushes and cause lots of compactions, etc, which just makes // lots of little flushes and cause lots of compactions, etc, which just makes
@ -211,21 +247,22 @@ class MemStoreFlusher implements FlushRequester {
case ABOVE_OFFHEAP_HIGHER_MARK: case ABOVE_OFFHEAP_HIGHER_MARK:
case ABOVE_OFFHEAP_LOWER_MARK: case ABOVE_OFFHEAP_LOWER_MARK:
regionToFlushSize = regionToFlush.getMemStoreOffHeapSize(); regionToFlushSize = regionToFlush.getMemStoreOffHeapSize();
bestRegionReplicaSize = bestRegionReplica.getMemStoreOffHeapSize(); bestRegionReplicaSize = getMemStoreOffHeapSize(bestRegionReplica);
break; break;
case ABOVE_ONHEAP_HIGHER_MARK: case ABOVE_ONHEAP_HIGHER_MARK:
case ABOVE_ONHEAP_LOWER_MARK: case ABOVE_ONHEAP_LOWER_MARK:
regionToFlushSize = regionToFlush.getMemStoreHeapSize(); regionToFlushSize = regionToFlush.getMemStoreHeapSize();
bestRegionReplicaSize = bestRegionReplica.getMemStoreHeapSize(); bestRegionReplicaSize = getMemStoreHeapSize(bestRegionReplica);
break; break;
default: default:
regionToFlushSize = regionToFlush.getMemStoreDataSize(); regionToFlushSize = regionToFlush.getMemStoreDataSize();
bestRegionReplicaSize = bestRegionReplica.getMemStoreDataSize(); bestRegionReplicaSize = getMemStoreDataSize(bestRegionReplica);
} }
Preconditions.checkState( Preconditions.checkState(
(regionToFlush != null && regionToFlushSize > 0) || (regionToFlush != null && regionToFlushSize > 0) || bestRegionReplicaSize > 0);
(bestRegionReplica != null && bestRegionReplicaSize > 0));
if (regionToFlush == null || if (regionToFlush == null ||
(bestRegionReplica != null && (bestRegionReplica != null &&
@ -266,6 +303,27 @@ class MemStoreFlusher implements FlushRequester {
return true; return true;
} }
/**
* @return Return memstore offheap size or null if <code>r</code> is null
*/
private static long getMemStoreOffHeapSize(HRegion r) {
return r == null? 0: r.getMemStoreOffHeapSize();
}
/**
* @return Return memstore heap size or null if <code>r</code> is null
*/
private static long getMemStoreHeapSize(HRegion r) {
return r == null? 0: r.getMemStoreHeapSize();
}
/**
* @return Return memstore data size or null if <code>r</code> is null
*/
private static long getMemStoreDataSize(HRegion r) {
return r == null? 0: r.getMemStoreDataSize();
}
private class FlushHandler extends HasThread { private class FlushHandler extends HasThread {
private FlushHandler(String name) { private FlushHandler(String name) {
@ -279,7 +337,7 @@ class MemStoreFlusher implements FlushRequester {
try { try {
wakeupPending.set(false); // allow someone to wake us up again wakeupPending.set(false); // allow someone to wake us up again
fqe = flushQueue.poll(threadWakeFrequency, TimeUnit.MILLISECONDS); fqe = flushQueue.poll(threadWakeFrequency, TimeUnit.MILLISECONDS);
if (fqe == null || fqe instanceof WakeupFlushThread) { if (fqe == null || fqe == WAKEUPFLUSH_INSTANCE) {
FlushType type = isAboveLowWaterMark(); FlushType type = isAboveLowWaterMark();
if (type != FlushType.NORMAL) { if (type != FlushType.NORMAL) {
LOG.debug("Flush thread woke up because memory above low water=" LOG.debug("Flush thread woke up because memory above low water="
@ -332,7 +390,7 @@ class MemStoreFlusher implements FlushRequester {
private void wakeupFlushThread() { private void wakeupFlushThread() {
if (wakeupPending.compareAndSet(false, true)) { if (wakeupPending.compareAndSet(false, true)) {
flushQueue.add(new WakeupFlushThread()); flushQueue.add(WAKEUPFLUSH_INSTANCE);
} }
} }
@ -759,21 +817,6 @@ class MemStoreFlusher implements FlushRequester {
interface FlushQueueEntry extends Delayed { interface FlushQueueEntry extends Delayed {
} }
/**
* Token to insert into the flush queue that ensures that the flusher does not sleep
*/
static class WakeupFlushThread implements FlushQueueEntry {
@Override
public long getDelay(TimeUnit unit) {
return 0;
}
@Override
public int compareTo(Delayed o) {
return -1;
}
}
/** /**
* Datastructure used in the flush queue. Holds region and retry count. * Datastructure used in the flush queue. Holds region and retry count.
* Keeps tabs on how old this object is. Implements {@link Delayed}. On * Keeps tabs on how old this object is. Implements {@link Delayed}. On

View File

@ -1206,7 +1206,6 @@ public class RSRpcServices implements HBaseRPCErrorHandler,
throw new IllegalArgumentException("Failed resolve of " + initialIsa); throw new IllegalArgumentException("Failed resolve of " + initialIsa);
} }
priority = createPriority(); priority = createPriority();
String hostname = initialIsa.getHostName();
// Using Address means we don't get the IP too. Shorten it more even to just the host name // Using Address means we don't get the IP too. Shorten it more even to just the host name
// w/o the domain. // w/o the domain.
String name = rs.getProcessName() + "/" + String name = rs.getProcessName() + "/" +

View File

@ -1206,6 +1206,8 @@ public class RegionCoprocessorHost
* @return true or false to return to client if default processing should be bypassed, * @return true or false to return to client if default processing should be bypassed,
* or null otherwise * or null otherwise
*/ */
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="NP_BOOLEAN_RETURN_NULL",
justification="TODO: Fix")
public Boolean preCheckAndDeleteAfterRowLock(final byte[] row, final byte[] family, public Boolean preCheckAndDeleteAfterRowLock(final byte[] row, final byte[] family,
final byte[] qualifier, final CompareOperator op, final ByteArrayComparable comparator, final byte[] qualifier, final CompareOperator op, final ByteArrayComparable comparator,
final Delete delete) throws IOException { final Delete delete) throws IOException {

View File

@ -52,6 +52,7 @@ import org.apache.hadoop.hbase.wal.WALEdit;
import org.apache.hadoop.hbase.wal.WALKeyImpl; import org.apache.hadoop.hbase.wal.WALKeyImpl;
import org.apache.hadoop.hbase.wal.WALProvider.AsyncWriter; import org.apache.hadoop.hbase.wal.WALProvider.AsyncWriter;
import org.apache.hadoop.hdfs.protocol.DatanodeInfo; import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
import org.apache.hbase.thirdparty.com.google.common.base.Preconditions;
import org.apache.htrace.core.TraceScope; import org.apache.htrace.core.TraceScope;
import org.apache.yetus.audience.InterfaceAudience; import org.apache.yetus.audience.InterfaceAudience;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -651,11 +652,12 @@ public class AsyncFSWAL extends AbstractFSWAL<AsyncWriter> {
@Override @Override
protected void doReplaceWriter(Path oldPath, Path newPath, AsyncWriter nextWriter) protected void doReplaceWriter(Path oldPath, Path newPath, AsyncWriter nextWriter)
throws IOException { throws IOException {
Preconditions.checkNotNull(nextWriter);
waitForSafePoint(); waitForSafePoint();
long oldFileLen = closeWriter(); long oldFileLen = closeWriter();
logRollAndSetupWalProps(oldPath, newPath, oldFileLen); logRollAndSetupWalProps(oldPath, newPath, oldFileLen);
this.writer = nextWriter; this.writer = nextWriter;
if (nextWriter != null && nextWriter instanceof AsyncProtobufLogWriter) { if (nextWriter instanceof AsyncProtobufLogWriter) {
this.fsOut = ((AsyncProtobufLogWriter) nextWriter).getOutput(); this.fsOut = ((AsyncProtobufLogWriter) nextWriter).getOutput();
} }
this.fileLengthAtLastSync = nextWriter.getLength(); this.fileLengthAtLastSync = nextWriter.getLength();

View File

@ -336,7 +336,12 @@ public class MajorCompactor {
"ERROR: Unable to parse command-line arguments " + Arrays.toString(args) + " due to: " "ERROR: Unable to parse command-line arguments " + Arrays.toString(args) + " due to: "
+ parseException); + parseException);
printUsage(options); printUsage(options);
return;
}
if (commandLine == null) {
System.out.println("ERROR: Failed parse, empty commandLine; " + Arrays.toString(args));
printUsage(options);
return;
} }
String tableName = commandLine.getOptionValue("table"); String tableName = commandLine.getOptionValue("table");
String cf = commandLine.getOptionValue("cf", null); String cf = commandLine.getOptionValue("cf", null);
@ -353,7 +358,7 @@ public class MajorCompactor {
String quorum = String quorum =
commandLine.getOptionValue("zk", configuration.get(HConstants.ZOOKEEPER_QUORUM)); commandLine.getOptionValue("zk", configuration.get(HConstants.ZOOKEEPER_QUORUM));
String rootDir = commandLine.getOptionValue("rootDir", configuration.get(HConstants.HBASE_DIR)); String rootDir = commandLine.getOptionValue("rootDir", configuration.get(HConstants.HBASE_DIR));
long sleep = Long.valueOf(commandLine.getOptionValue("sleep", Long.toString(30000))); long sleep = Long.parseLong(commandLine.getOptionValue("sleep", Long.toString(30000)));
configuration.set(HConstants.HBASE_DIR, rootDir); configuration.set(HConstants.HBASE_DIR, rootDir);
configuration.set(HConstants.ZOOKEEPER_QUORUM, quorum); configuration.set(HConstants.ZOOKEEPER_QUORUM, quorum);