HBASE-4935 hbase 0.92.0 doesn't work going against 0.20.205.0, its packaged hadoop

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1221033 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Stack 2011-12-20 00:10:02 +00:00
parent 1222383f1d
commit 77e16e8027
2 changed files with 25 additions and 16 deletions

View File

@ -457,6 +457,7 @@ Release 0.92.0 - Unreleased
HBASE-4946 HTable.coprocessorExec (and possibly coprocessorProxy) does not work with HBASE-4946 HTable.coprocessorExec (and possibly coprocessorProxy) does not work with
dynamically loaded coprocessors (Andrei Dragomir) dynamically loaded coprocessors (Andrei Dragomir)
HBASE-5026 Add coprocessor hook to HRegionServer.ScannerListener.leaseExpired() HBASE-5026 Add coprocessor hook to HRegionServer.ScannerListener.leaseExpired()
HBASE-4935 hbase 0.92.0 doesn't work going against 0.20.205.0, its packaged hadoop
TESTS TESTS
HBASE-4450 test for number of blocks read: to serve as baseline for expected HBASE-4450 test for number of blocks read: to serve as baseline for expected

View File

@ -26,7 +26,8 @@ import java.lang.Class;
import java.lang.reflect.Constructor; import java.lang.reflect.Constructor;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.Arrays;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
@ -82,8 +83,8 @@ public class SequenceFileLogReader implements HLog.Reader {
// This section can be confusing. It is specific to how HDFS works. // This section can be confusing. It is specific to how HDFS works.
// Let me try to break it down. This is the problem: // Let me try to break it down. This is the problem:
// //
// 1. HDFS DataNodes update the NameNode about a filename's length // 1. HDFS DataNodes update the NameNode about a filename's length
// on block boundaries or when a file is closed. Therefore, // on block boundaries or when a file is closed. Therefore,
// if an RS dies, then the NN's fs.getLength() can be out of date // if an RS dies, then the NN's fs.getLength() can be out of date
// 2. this.in.available() would work, but it returns int & // 2. this.in.available() would work, but it returns int &
// therefore breaks for files > 2GB (happens on big clusters) // therefore breaks for files > 2GB (happens on big clusters)
@ -91,7 +92,7 @@ public class SequenceFileLogReader implements HLog.Reader {
// 4. DFSInputStream is wrapped 2 levels deep : this.in.in // 4. DFSInputStream is wrapped 2 levels deep : this.in.in
// //
// So, here we adjust getPos() using getFileLength() so the // So, here we adjust getPos() using getFileLength() so the
// SequenceFile.Reader constructor (aka: first invocation) comes out // SequenceFile.Reader constructor (aka: first invocation) comes out
// with the correct end of the file: // with the correct end of the file:
// this.end = in.getPos() + length; // this.end = in.getPos() + length;
@Override @Override
@ -104,13 +105,20 @@ public class SequenceFileLogReader implements HLog.Reader {
Field fIn = FilterInputStream.class.getDeclaredField("in"); Field fIn = FilterInputStream.class.getDeclaredField("in");
fIn.setAccessible(true); fIn.setAccessible(true);
Object realIn = fIn.get(this.in); Object realIn = fIn.get(this.in);
Method getFileLength = realIn.getClass(). // In hadoop 0.22, DFSInputStream is a standalone class. Before this,
getMethod("getFileLength", new Class<?> []{}); // it was an inner class of DFSClient.
getFileLength.setAccessible(true); if (realIn.getClass().getName().endsWith("DFSInputStream")) {
long realLength = ((Long)getFileLength. Method getFileLength = realIn.getClass().
invoke(realIn, new Object []{})).longValue(); getDeclaredMethod("getFileLength", new Class<?> []{});
assert(realLength >= this.length); getFileLength.setAccessible(true);
adjust = realLength - this.length; long realLength = ((Long)getFileLength.
invoke(realIn, new Object []{})).longValue();
assert(realLength >= this.length);
adjust = realLength - this.length;
} else {
LOG.info("Input stream class: " + realIn.getClass().getName() +
", not adjusting length");
}
} catch(Exception e) { } catch(Exception e) {
SequenceFileLogReader.LOG.warn( SequenceFileLogReader.LOG.warn(
"Error while trying to get accurate file length. " + "Error while trying to get accurate file length. " +
@ -142,7 +150,7 @@ public class SequenceFileLogReader implements HLog.Reader {
/** /**
* This constructor allows a specific HLogKey implementation to override that * This constructor allows a specific HLogKey implementation to override that
* which would otherwise be chosen via configuration property. * which would otherwise be chosen via configuration property.
* *
* @param keyClass * @param keyClass
*/ */
public SequenceFileLogReader(Class<? extends HLogKey> keyClass) { public SequenceFileLogReader(Class<? extends HLogKey> keyClass) {
@ -189,7 +197,7 @@ public class SequenceFileLogReader implements HLog.Reader {
throw new IOException(iae); throw new IOException(iae);
} }
} }
WALEdit val = new WALEdit(); WALEdit val = new WALEdit();
e = new HLog.Entry(key, val); e = new HLog.Entry(key, val);
} }
@ -235,8 +243,8 @@ public class SequenceFileLogReader implements HLog.Reader {
} catch(Exception e) { /* reflection fail. keep going */ } } catch(Exception e) { /* reflection fail. keep going */ }
String msg = (this.path == null? "": this.path.toString()) + String msg = (this.path == null? "": this.path.toString()) +
", entryStart=" + entryStart + ", pos=" + pos + ", entryStart=" + entryStart + ", pos=" + pos +
((end == Long.MAX_VALUE) ? "" : ", end=" + end) + ((end == Long.MAX_VALUE) ? "" : ", end=" + end) +
", edit=" + this.edit; ", edit=" + this.edit;
// Enhance via reflection so we don't change the original class type // Enhance via reflection so we don't change the original class type
@ -246,7 +254,7 @@ public class SequenceFileLogReader implements HLog.Reader {
.newInstance(msg) .newInstance(msg)
.initCause(ioe); .initCause(ioe);
} catch(Exception e) { /* reflection fail. keep going */ } } catch(Exception e) { /* reflection fail. keep going */ }
return ioe; return ioe;
} }
} }