HDFS: implement ByteBufferReadable

fix https://github.com/chrislusf/seaweedfs/issues/1645
This commit is contained in:
Chris Lu 2020-12-01 17:20:31 -08:00
parent 04062c56c7
commit a9efaa6385
2 changed files with 20 additions and 4 deletions

View file

@ -2,6 +2,7 @@ package seaweed.hdfs;
// based on org.apache.hadoop.fs.azurebfs.services.AbfsInputStream // based on org.apache.hadoop.fs.azurebfs.services.AbfsInputStream
import org.apache.hadoop.fs.ByteBufferReadable;
import org.apache.hadoop.fs.FSExceptionMessages; import org.apache.hadoop.fs.FSExceptionMessages;
import org.apache.hadoop.fs.FSInputStream; import org.apache.hadoop.fs.FSInputStream;
import org.apache.hadoop.fs.FileSystem.Statistics; import org.apache.hadoop.fs.FileSystem.Statistics;
@ -13,9 +14,10 @@ import seaweedfs.client.SeaweedRead;
import java.io.EOFException; import java.io.EOFException;
import java.io.IOException; import java.io.IOException;
import java.nio.ByteBuffer;
import java.util.List; import java.util.List;
public class SeaweedInputStream extends FSInputStream { public class SeaweedInputStream extends FSInputStream implements ByteBufferReadable {
private static final Logger LOG = LoggerFactory.getLogger(SeaweedInputStream.class); private static final Logger LOG = LoggerFactory.getLogger(SeaweedInputStream.class);
@ -85,7 +87,7 @@ public class SeaweedInputStream extends FSInputStream {
} }
long bytesRead = 0; long bytesRead = 0;
if (position+len < entry.getContent().size()) { if (position+len <= entry.getContent().size()) {
entry.getContent().copyTo(b, (int) position, (int) off, len); entry.getContent().copyTo(b, (int) position, (int) off, len);
} else { } else {
bytesRead = SeaweedRead.read(this.filerGrpcClient, this.visibleIntervalList, this.position, b, off, len, SeaweedRead.fileSize(entry)); bytesRead = SeaweedRead.read(this.filerGrpcClient, this.visibleIntervalList, this.position, b, off, len, SeaweedRead.fileSize(entry));
@ -106,6 +108,12 @@ public class SeaweedInputStream extends FSInputStream {
} }
// implement ByteBufferReadable
@Override
public synchronized int read(ByteBuffer buf) throws IOException {
return read(buf.array(), buf.position(), buf.remaining());
}
/** /**
* Seek to given position in stream. * Seek to given position in stream.
* *

View file

@ -2,6 +2,7 @@ package seaweed.hdfs;
// based on org.apache.hadoop.fs.azurebfs.services.AbfsInputStream // based on org.apache.hadoop.fs.azurebfs.services.AbfsInputStream
import org.apache.hadoop.fs.ByteBufferReadable;
import org.apache.hadoop.fs.FSExceptionMessages; import org.apache.hadoop.fs.FSExceptionMessages;
import org.apache.hadoop.fs.FSInputStream; import org.apache.hadoop.fs.FSInputStream;
import org.apache.hadoop.fs.FileSystem.Statistics; import org.apache.hadoop.fs.FileSystem.Statistics;
@ -13,9 +14,10 @@ import seaweedfs.client.SeaweedRead;
import java.io.EOFException; import java.io.EOFException;
import java.io.IOException; import java.io.IOException;
import java.nio.ByteBuffer;
import java.util.List; import java.util.List;
public class SeaweedInputStream extends FSInputStream { public class SeaweedInputStream extends FSInputStream implements ByteBufferReadable {
private static final Logger LOG = LoggerFactory.getLogger(SeaweedInputStream.class); private static final Logger LOG = LoggerFactory.getLogger(SeaweedInputStream.class);
@ -85,7 +87,7 @@ public class SeaweedInputStream extends FSInputStream {
} }
long bytesRead = 0; long bytesRead = 0;
if (position+len < entry.getContent().size()) { if (position+len <= entry.getContent().size()) {
entry.getContent().copyTo(b, (int) position, (int) off, len); entry.getContent().copyTo(b, (int) position, (int) off, len);
} else { } else {
bytesRead = SeaweedRead.read(this.filerGrpcClient, this.visibleIntervalList, this.position, b, off, len, SeaweedRead.fileSize(entry)); bytesRead = SeaweedRead.read(this.filerGrpcClient, this.visibleIntervalList, this.position, b, off, len, SeaweedRead.fileSize(entry));
@ -106,6 +108,12 @@ public class SeaweedInputStream extends FSInputStream {
} }
// implement ByteBufferReadable
@Override
public synchronized int read(ByteBuffer buf) throws IOException {
return read(buf.array(), buf.position(), buf.remaining());
}
/** /**
* Seek to given position in stream. * Seek to given position in stream.
* *