HBASE-1370 re-enable LZO using hadoop-gpl-compression library

git-svn-id: https://svn.apache.org/repos/asf/hadoop/hbase/trunk@772432 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Stack 2009-05-06 21:26:09 +00:00
parent 2597f74d10
commit 6566301e47
3 changed files with 65 additions and 53 deletions

View File

@ -203,6 +203,8 @@ Release 0.20.0 - Unreleased
created without supplying a column list unlike the other APIs. created without supplying a column list unlike the other APIs.
(Tim Sell via Stack) (Tim Sell via Stack)
HBASE-1341 HTable pooler HBASE-1341 HTable pooler
HBASE-1379 re-enable LZO using hadoop-gpl-compression library
(Ryan Rawson via Stack)
Release 0.19.0 - 01/21/2009 Release 0.19.0 - 01/21/2009
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -59,7 +59,8 @@ public class HColumnDescriptor implements ISerializable, WritableComparable<HCol
/** /**
* The type of compression. * The type of compression.
* @see org.apache.hadoop.io.SequenceFile.Writer * @see org.apache.hadoop.io.SequenceFile.Writer
* @deprecated * @deprecated Compression now means which compression library
* rather than 'what' to cmopress. See {@link Compression.Algorithm}
*/ */
@Deprecated @Deprecated
public static enum CompressionType { public static enum CompressionType {
@ -426,11 +427,16 @@ public class HColumnDescriptor implements ISerializable, WritableComparable<HCol
} }
/** /**
* Compression types supported in hbase.
* LZO is not bundled as part of the hbase distribution.
* See <a href="http://wiki.apache.org/hadoop/UsingLzoCompression">LZO Compression</a>
* for how to enable it.
* @param type Compression type setting. * @param type Compression type setting.
*/ */
public void setCompressionType(Compression.Algorithm type) { public void setCompressionType(Compression.Algorithm type) {
String compressionType; String compressionType;
switch (type) { switch (type) {
case LZO: compressionType = "LZO"; break;
case GZ: compressionType = "GZ"; break; case GZ: compressionType = "GZ"; break;
default: compressionType = "NONE"; break; default: compressionType = "NONE"; break;
} }

View File

@ -33,6 +33,7 @@ import org.apache.hadoop.io.compress.CompressionOutputStream;
import org.apache.hadoop.io.compress.Compressor; import org.apache.hadoop.io.compress.Compressor;
import org.apache.hadoop.io.compress.Decompressor; import org.apache.hadoop.io.compress.Decompressor;
import org.apache.hadoop.io.compress.GzipCodec; import org.apache.hadoop.io.compress.GzipCodec;
import org.apache.hadoop.io.compress.DefaultCodec;
/** /**
* Compression related stuff. * Compression related stuff.
@ -72,25 +73,35 @@ public final class Compression {
*/ */
public static enum Algorithm { public static enum Algorithm {
LZO("lzo") { LZO("lzo") {
// Use base type to avoid compile-time dependencies.
private DefaultCodec lzoCodec;
@Override @Override
CompressionCodec getCodec() { DefaultCodec getCodec() {
throw new UnsupportedOperationException("LZO compression is disabled for now"); if (lzoCodec == null) {
Configuration conf = new Configuration();
conf.setBoolean("hadoop.native.lib", true);
try {
Class externalCodec =
ClassLoader.getSystemClassLoader().loadClass("com.hadoop.compression.lzo.LzoCodec");
lzoCodec = (DefaultCodec) externalCodec.newInstance();
lzoCodec.setConf(conf);
} catch (ClassNotFoundException e) {
throw new RuntimeException(e);
} catch (InstantiationException e) {
throw new RuntimeException(e);
} catch (IllegalAccessException e) {
throw new RuntimeException(e);
} }
@Override
public InputStream createDecompressionStream(InputStream downStream, Decompressor decompressor, int downStreamBufferSize) throws IOException {
throw new UnsupportedOperationException("LZO compression is disabled for now");
} }
@Override return lzoCodec;
public OutputStream createCompressionStream(OutputStream downStream, Compressor compressor, int downStreamBufferSize) throws IOException {
throw new UnsupportedOperationException("LZO compression is disabled for now");
} }
}, },
GZ("gz") { GZ("gz") {
private GzipCodec codec; private GzipCodec codec;
@Override @Override
CompressionCodec getCodec() { DefaultCodec getCodec() {
if (codec == null) { if (codec == null) {
Configuration conf = new Configuration(); Configuration conf = new Configuration();
conf.setBoolean("hadoop.native.lib", true); conf.setBoolean("hadoop.native.lib", true);
@ -100,45 +111,11 @@ public final class Compression {
return codec; return codec;
} }
@Override
public synchronized InputStream createDecompressionStream(
InputStream downStream, Decompressor decompressor,
int downStreamBufferSize) throws IOException {
// Set the internal buffer size to read from down stream.
if (downStreamBufferSize > 0) {
codec.getConf().setInt("io.file.buffer.size", downStreamBufferSize);
}
CompressionInputStream cis =
codec.createInputStream(downStream, decompressor);
BufferedInputStream bis2 = new BufferedInputStream(cis, DATA_IBUF_SIZE);
return bis2;
}
@Override
public synchronized OutputStream createCompressionStream(
OutputStream downStream, Compressor compressor,
int downStreamBufferSize) throws IOException {
OutputStream bos1 = null;
if (downStreamBufferSize > 0) {
bos1 = new BufferedOutputStream(downStream, downStreamBufferSize);
}
else {
bos1 = downStream;
}
codec.getConf().setInt("io.file.buffer.size", 32 * 1024);
CompressionOutputStream cos =
codec.createOutputStream(bos1, compressor);
BufferedOutputStream bos2 =
new BufferedOutputStream(new FinishOnFlushCompressionStream(cos),
DATA_OBUF_SIZE);
return bos2;
}
}, },
NONE("none") { NONE("none") {
@Override @Override
CompressionCodec getCodec() { DefaultCodec getCodec() {
return null; return null;
} }
@ -179,15 +156,42 @@ public final class Compression {
this.compressName = name; this.compressName = name;
} }
abstract CompressionCodec getCodec(); abstract DefaultCodec getCodec();
public abstract InputStream createDecompressionStream( public InputStream createDecompressionStream(
InputStream downStream, Decompressor decompressor, InputStream downStream, Decompressor decompressor,
int downStreamBufferSize) throws IOException; int downStreamBufferSize) throws IOException {
DefaultCodec codec = getCodec();
// Set the internal buffer size to read from down stream.
if (downStreamBufferSize > 0) {
codec.getConf().setInt("io.file.buffer.size", downStreamBufferSize);
}
CompressionInputStream cis =
codec.createInputStream(downStream, decompressor);
BufferedInputStream bis2 = new BufferedInputStream(cis, DATA_IBUF_SIZE);
return bis2;
public abstract OutputStream createCompressionStream( }
public OutputStream createCompressionStream(
OutputStream downStream, Compressor compressor, int downStreamBufferSize) OutputStream downStream, Compressor compressor, int downStreamBufferSize)
throws IOException; throws IOException {
DefaultCodec codec = getCodec();
OutputStream bos1 = null;
if (downStreamBufferSize > 0) {
bos1 = new BufferedOutputStream(downStream, downStreamBufferSize);
}
else {
bos1 = downStream;
}
codec.getConf().setInt("io.file.buffer.size", 32 * 1024);
CompressionOutputStream cos =
codec.createOutputStream(bos1, compressor);
BufferedOutputStream bos2 =
new BufferedOutputStream(new FinishOnFlushCompressionStream(cos),
DATA_OBUF_SIZE);
return bos2;
}
public Compressor getCompressor() { public Compressor getCompressor() {
CompressionCodec codec = getCodec(); CompressionCodec codec = getCodec();