HDFS-347: style cleanups. Contributed by Colin Patrick McCabe.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/HDFS-347@1446830 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
27e158362c
commit
3a417cbf1d
|
@ -51,7 +51,7 @@ public class DomainSocket implements Closeable {
|
||||||
} else if (!NativeCodeLoader.isNativeCodeLoaded()) {
|
} else if (!NativeCodeLoader.isNativeCodeLoaded()) {
|
||||||
loadingFailureReason = "libhadoop cannot be loaded.";
|
loadingFailureReason = "libhadoop cannot be loaded.";
|
||||||
} else {
|
} else {
|
||||||
String problem = "DomainSocket#anchorNative got error: unknown";
|
String problem;
|
||||||
try {
|
try {
|
||||||
anchorNative();
|
anchorNative();
|
||||||
problem = null;
|
problem = null;
|
||||||
|
@ -131,18 +131,100 @@ public class DomainSocket implements Closeable {
|
||||||
return path.replace("_PORT", String.valueOf(port));
|
return path.replace("_PORT", String.valueOf(port));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tracks the reference count of the file descriptor, and also whether it is
|
||||||
|
* open or closed.
|
||||||
|
*/
|
||||||
|
private static class Status {
|
||||||
|
/**
|
||||||
|
* Bit mask representing a closed domain socket.
|
||||||
|
*/
|
||||||
|
private static final int STATUS_CLOSED_MASK = 1 << 30;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Status bits
|
* Status bits
|
||||||
*
|
*
|
||||||
* Bit 30: 0 = DomainSocket open, 1 = DomainSocket closed
|
* Bit 30: 0 = DomainSocket open, 1 = DomainSocket closed
|
||||||
* Bits 29 to 0: the reference count.
|
* Bits 29 to 0: the reference count.
|
||||||
*/
|
*/
|
||||||
private final AtomicInteger status;
|
private final AtomicInteger bits = new AtomicInteger(0);
|
||||||
|
|
||||||
|
Status() { }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bit mask representing a closed domain socket.
|
* Increment the reference count of the underlying file descriptor.
|
||||||
|
*
|
||||||
|
* @throws ClosedChannelException If the file descriptor is closed.
|
||||||
*/
|
*/
|
||||||
private static final int STATUS_CLOSED_MASK = 1 << 30;
|
void reference() throws ClosedChannelException {
|
||||||
|
int curBits = bits.incrementAndGet();
|
||||||
|
if ((curBits & STATUS_CLOSED_MASK) != 0) {
|
||||||
|
bits.decrementAndGet();
|
||||||
|
throw new ClosedChannelException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Decrement the reference count of the underlying file descriptor.
|
||||||
|
*
|
||||||
|
* @param checkClosed Whether to throw an exception if the file
|
||||||
|
* descriptor is closed.
|
||||||
|
*
|
||||||
|
* @throws AsynchronousCloseException If the file descriptor is closed and
|
||||||
|
* checkClosed is set.
|
||||||
|
*/
|
||||||
|
void unreference(boolean checkClosed) throws AsynchronousCloseException {
|
||||||
|
int newCount = bits.decrementAndGet();
|
||||||
|
assert (newCount & ~STATUS_CLOSED_MASK) >= 0;
|
||||||
|
if (checkClosed && ((newCount & STATUS_CLOSED_MASK) != 0)) {
|
||||||
|
throw new AsynchronousCloseException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return true if the file descriptor is currently open.
|
||||||
|
*
|
||||||
|
* @return True if the file descriptor is currently open.
|
||||||
|
*/
|
||||||
|
boolean isOpen() {
|
||||||
|
return ((bits.get() & STATUS_CLOSED_MASK) == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mark the file descriptor as closed.
|
||||||
|
*
|
||||||
|
* Once the file descriptor is closed, it cannot be reopened.
|
||||||
|
*
|
||||||
|
* @return The current reference count.
|
||||||
|
* @throws ClosedChannelException If someone else closes the file
|
||||||
|
* descriptor before we do.
|
||||||
|
*/
|
||||||
|
int setClosed() throws ClosedChannelException {
|
||||||
|
while (true) {
|
||||||
|
int curBits = bits.get();
|
||||||
|
if ((curBits & STATUS_CLOSED_MASK) != 0) {
|
||||||
|
throw new ClosedChannelException();
|
||||||
|
}
|
||||||
|
if (bits.compareAndSet(curBits, curBits | STATUS_CLOSED_MASK)) {
|
||||||
|
return curBits & (~STATUS_CLOSED_MASK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current reference count.
|
||||||
|
*
|
||||||
|
* @return The current reference count.
|
||||||
|
*/
|
||||||
|
int getReferenceCount() {
|
||||||
|
return bits.get() & (~STATUS_CLOSED_MASK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The socket status.
|
||||||
|
*/
|
||||||
|
private final Status status;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The file descriptor associated with this UNIX domain socket.
|
* The file descriptor associated with this UNIX domain socket.
|
||||||
|
@ -170,7 +252,7 @@ public class DomainSocket implements Closeable {
|
||||||
private final DomainChannel channel = new DomainChannel();
|
private final DomainChannel channel = new DomainChannel();
|
||||||
|
|
||||||
private DomainSocket(String path, int fd) {
|
private DomainSocket(String path, int fd) {
|
||||||
this.status = new AtomicInteger(0);
|
this.status = new Status();
|
||||||
this.fd = fd;
|
this.fd = fd;
|
||||||
this.path = path;
|
this.path = path;
|
||||||
}
|
}
|
||||||
|
@ -208,14 +290,14 @@ public class DomainSocket implements Closeable {
|
||||||
* @throws SocketTimeoutException If the accept timed out.
|
* @throws SocketTimeoutException If the accept timed out.
|
||||||
*/
|
*/
|
||||||
public DomainSocket accept() throws IOException {
|
public DomainSocket accept() throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
DomainSocket ret = new DomainSocket(path, accept0(fd));
|
DomainSocket ret = new DomainSocket(path, accept0(fd));
|
||||||
exc = false;
|
exc = false;
|
||||||
return ret;
|
return ret;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -235,37 +317,13 @@ public class DomainSocket implements Closeable {
|
||||||
return new DomainSocket(path, fd);
|
return new DomainSocket(path, fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Increment the reference count of the underlying file descriptor.
|
|
||||||
*
|
|
||||||
* @throws SocketException If the file descriptor is closed.
|
|
||||||
*/
|
|
||||||
private void fdRef() throws ClosedChannelException {
|
|
||||||
int bits = status.incrementAndGet();
|
|
||||||
if ((bits & STATUS_CLOSED_MASK) != 0) {
|
|
||||||
status.decrementAndGet();
|
|
||||||
throw new ClosedChannelException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Decrement the reference count of the underlying file descriptor.
|
|
||||||
*/
|
|
||||||
private void fdUnref(boolean checkClosed) throws AsynchronousCloseException {
|
|
||||||
int newCount = status.decrementAndGet();
|
|
||||||
assert (newCount & ~STATUS_CLOSED_MASK) >= 0;
|
|
||||||
if (checkClosed && ((newCount & STATUS_CLOSED_MASK) != 0)) {
|
|
||||||
throw new AsynchronousCloseException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return true if the file descriptor is currently open.
|
* Return true if the file descriptor is currently open.
|
||||||
*
|
*
|
||||||
* @return True if the file descriptor is currently open.
|
* @return True if the file descriptor is currently open.
|
||||||
*/
|
*/
|
||||||
public boolean isOpen() {
|
public boolean isOpen() {
|
||||||
return ((status.get() & STATUS_CLOSED_MASK) == 0);
|
return status.isOpen();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -296,29 +354,29 @@ public class DomainSocket implements Closeable {
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final int SND_BUF_SIZE = 1;
|
public static final int SEND_BUFFER_SIZE = 1;
|
||||||
public static final int RCV_BUF_SIZE = 2;
|
public static final int RECEIVE_BUFFER_SIZE = 2;
|
||||||
public static final int SND_TIMEO = 3;
|
public static final int SEND_TIMEOUT = 3;
|
||||||
public static final int RCV_TIMEO = 4;
|
public static final int RECEIVE_TIMEOUT = 4;
|
||||||
|
|
||||||
private static native void setAttribute0(int fd, int type, int val)
|
private static native void setAttribute0(int fd, int type, int val)
|
||||||
throws IOException;
|
throws IOException;
|
||||||
|
|
||||||
public void setAttribute(int type, int size) throws IOException {
|
public void setAttribute(int type, int size) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
setAttribute0(fd, type, size);
|
setAttribute0(fd, type, size);
|
||||||
exc = false;
|
exc = false;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private native int getAttribute0(int fd, int type) throws IOException;
|
private native int getAttribute0(int fd, int type) throws IOException;
|
||||||
|
|
||||||
public int getAttribute(int type) throws IOException {
|
public int getAttribute(int type) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
int attribute;
|
int attribute;
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
|
@ -326,7 +384,7 @@ public class DomainSocket implements Closeable {
|
||||||
exc = false;
|
exc = false;
|
||||||
return attribute;
|
return attribute;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -343,20 +401,17 @@ public class DomainSocket implements Closeable {
|
||||||
@Override
|
@Override
|
||||||
public void close() throws IOException {
|
public void close() throws IOException {
|
||||||
// Set the closed bit on this DomainSocket
|
// Set the closed bit on this DomainSocket
|
||||||
int bits;
|
int refCount;
|
||||||
while (true) {
|
try {
|
||||||
bits = status.get();
|
refCount = status.setClosed();
|
||||||
if ((bits & STATUS_CLOSED_MASK) != 0) {
|
} catch (ClosedChannelException e) {
|
||||||
return; // already closed
|
// Someone else already closed the DomainSocket.
|
||||||
}
|
return;
|
||||||
if (status.compareAndSet(bits, bits | STATUS_CLOSED_MASK)) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// Wait for all references to go away
|
// Wait for all references to go away
|
||||||
boolean didShutdown = false;
|
boolean didShutdown = false;
|
||||||
boolean interrupted = false;
|
boolean interrupted = false;
|
||||||
while ((bits & (~STATUS_CLOSED_MASK)) > 0) {
|
while (refCount > 0) {
|
||||||
if (!didShutdown) {
|
if (!didShutdown) {
|
||||||
try {
|
try {
|
||||||
// Calling shutdown on the socket will interrupt blocking system
|
// Calling shutdown on the socket will interrupt blocking system
|
||||||
|
@ -373,60 +428,57 @@ public class DomainSocket implements Closeable {
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
interrupted = true;
|
interrupted = true;
|
||||||
}
|
}
|
||||||
bits = status.get();
|
refCount = status.getReferenceCount();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close the file descriptor. After this point, the file descriptor
|
// At this point, nobody has a reference to the file descriptor,
|
||||||
// number will be reused by something else. Although this DomainSocket
|
// and nobody will be able to get one in the future either.
|
||||||
// object continues to hold the old file descriptor number (it's a final
|
// We now call close(2) on the file descriptor.
|
||||||
// field), we never use it again because we look at the closed bit and
|
// After this point, the file descriptor number will be reused by
|
||||||
// realize that this DomainSocket is not usable.
|
// something else. Although this DomainSocket object continues to hold
|
||||||
|
// the old file descriptor number (it's a final field), we never use it
|
||||||
|
// again because this DomainSocket is closed.
|
||||||
close0(fd);
|
close0(fd);
|
||||||
if (interrupted) {
|
if (interrupted) {
|
||||||
Thread.currentThread().interrupt();
|
Thread.currentThread().interrupt();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
private native static void sendFileDescriptors0(int fd,
|
||||||
* Clean up if the user forgets to close the socket.
|
FileDescriptor descriptors[],
|
||||||
*/
|
|
||||||
protected void finalize() throws IOException {
|
|
||||||
close();
|
|
||||||
}
|
|
||||||
|
|
||||||
private native static void sendFileDescriptors0(int fd, FileDescriptor jfds[],
|
|
||||||
byte jbuf[], int offset, int length) throws IOException;
|
byte jbuf[], int offset, int length) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send some FileDescriptor objects to the process on the other side of this
|
* Send some FileDescriptor objects to the process on the other side of this
|
||||||
* socket.
|
* socket.
|
||||||
*
|
*
|
||||||
* @param jfds The file descriptors to send.
|
* @param descriptors The file descriptors to send.
|
||||||
* @param jbuf Some bytes to send. You must send at least
|
* @param jbuf Some bytes to send. You must send at least
|
||||||
* one byte.
|
* one byte.
|
||||||
* @param offset The offset in the jbuf array to start at.
|
* @param offset The offset in the jbuf array to start at.
|
||||||
* @param length Length of the jbuf array to use.
|
* @param length Length of the jbuf array to use.
|
||||||
*/
|
*/
|
||||||
public void sendFileDescriptors(FileDescriptor jfds[],
|
public void sendFileDescriptors(FileDescriptor descriptors[],
|
||||||
byte jbuf[], int offset, int length) throws IOException {
|
byte jbuf[], int offset, int length) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
sendFileDescriptors0(fd, jfds, jbuf, offset, length);
|
sendFileDescriptors0(fd, descriptors, jbuf, offset, length);
|
||||||
exc = false;
|
exc = false;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native int receiveFileDescriptors0(int fd, FileDescriptor[] jfds,
|
private static native int receiveFileDescriptors0(int fd,
|
||||||
|
FileDescriptor[] descriptors,
|
||||||
byte jbuf[], int offset, int length) throws IOException;
|
byte jbuf[], int offset, int length) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Receive some FileDescriptor objects from the process on the other side of
|
* Receive some FileDescriptor objects from the process on the other side of
|
||||||
* this socket.
|
* this socket.
|
||||||
*
|
*
|
||||||
* @param jfds (output parameter) Array of FileDescriptors.
|
* @param descriptors (output parameter) Array of FileDescriptors.
|
||||||
* We will fill as many slots as possible with file
|
* We will fill as many slots as possible with file
|
||||||
* descriptors passed from the remote process. The
|
* descriptors passed from the remote process. The
|
||||||
* other slots will contain NULL.
|
* other slots will contain NULL.
|
||||||
|
@ -443,16 +495,16 @@ public class DomainSocket implements Closeable {
|
||||||
* otherwise, it will be positive.
|
* otherwise, it will be positive.
|
||||||
* @throws IOException if there was an I/O error.
|
* @throws IOException if there was an I/O error.
|
||||||
*/
|
*/
|
||||||
public int receiveFileDescriptors(FileDescriptor[] jfds,
|
public int receiveFileDescriptors(FileDescriptor[] descriptors,
|
||||||
byte jbuf[], int offset, int length) throws IOException {
|
byte jbuf[], int offset, int length) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
int nBytes = receiveFileDescriptors0(fd, jfds, jbuf, offset, length);
|
int nBytes = receiveFileDescriptors0(fd, descriptors, jbuf, offset, length);
|
||||||
exc = false;
|
exc = false;
|
||||||
return nBytes;
|
return nBytes;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -462,44 +514,44 @@ public class DomainSocket implements Closeable {
|
||||||
*
|
*
|
||||||
* See {@link DomainSocket#recvFileInputStreams(ByteBuffer)}
|
* See {@link DomainSocket#recvFileInputStreams(ByteBuffer)}
|
||||||
*/
|
*/
|
||||||
public int recvFileInputStreams(FileInputStream[] fis, byte buf[],
|
public int recvFileInputStreams(FileInputStream[] streams, byte buf[],
|
||||||
int offset, int length) throws IOException {
|
int offset, int length) throws IOException {
|
||||||
FileDescriptor fds[] = new FileDescriptor[fis.length];
|
FileDescriptor descriptors[] = new FileDescriptor[streams.length];
|
||||||
boolean success = false;
|
boolean success = false;
|
||||||
for (int i = 0; i < fis.length; i++) {
|
for (int i = 0; i < streams.length; i++) {
|
||||||
fis[i] = null;
|
streams[i] = null;
|
||||||
}
|
}
|
||||||
fdRef();
|
status.reference();
|
||||||
try {
|
try {
|
||||||
int ret = receiveFileDescriptors0(fd, fds, buf, offset, length);
|
int ret = receiveFileDescriptors0(fd, descriptors, buf, offset, length);
|
||||||
for (int i = 0, j = 0; i < fds.length; i++) {
|
for (int i = 0, j = 0; i < descriptors.length; i++) {
|
||||||
if (fds[i] != null) {
|
if (descriptors[i] != null) {
|
||||||
fis[j++] = new FileInputStream(fds[i]);
|
streams[j++] = new FileInputStream(descriptors[i]);
|
||||||
fds[i] = null;
|
descriptors[i] = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
success = true;
|
success = true;
|
||||||
return ret;
|
return ret;
|
||||||
} finally {
|
} finally {
|
||||||
if (!success) {
|
if (!success) {
|
||||||
for (int i = 0; i < fds.length; i++) {
|
for (int i = 0; i < descriptors.length; i++) {
|
||||||
if (fds[i] != null) {
|
if (descriptors[i] != null) {
|
||||||
try {
|
try {
|
||||||
closeFileDescriptor0(fds[i]);
|
closeFileDescriptor0(descriptors[i]);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
LOG.warn(t);
|
LOG.warn(t);
|
||||||
}
|
}
|
||||||
} else if (fis[i] != null) {
|
} else if (streams[i] != null) {
|
||||||
try {
|
try {
|
||||||
fis[i].close();
|
streams[i].close();
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
LOG.warn(t);
|
LOG.warn(t);
|
||||||
} finally {
|
} finally {
|
||||||
fis[i] = null; }
|
streams[i] = null; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fdUnref(!success);
|
status.unreference(!success);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -523,7 +575,7 @@ public class DomainSocket implements Closeable {
|
||||||
public class DomainInputStream extends InputStream {
|
public class DomainInputStream extends InputStream {
|
||||||
@Override
|
@Override
|
||||||
public int read() throws IOException {
|
public int read() throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
byte b[] = new byte[1];
|
byte b[] = new byte[1];
|
||||||
|
@ -531,33 +583,33 @@ public class DomainSocket implements Closeable {
|
||||||
exc = false;
|
exc = false;
|
||||||
return (ret >= 0) ? b[0] : -1;
|
return (ret >= 0) ? b[0] : -1;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int read(byte b[], int off, int len) throws IOException {
|
public int read(byte b[], int off, int len) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
int nRead = DomainSocket.readArray0(DomainSocket.this.fd, b, off, len);
|
int nRead = DomainSocket.readArray0(DomainSocket.this.fd, b, off, len);
|
||||||
exc = false;
|
exc = false;
|
||||||
return nRead;
|
return nRead;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int available() throws IOException {
|
public int available() throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
int nAvailable = DomainSocket.available0(DomainSocket.this.fd);
|
int nAvailable = DomainSocket.available0(DomainSocket.this.fd);
|
||||||
exc = false;
|
exc = false;
|
||||||
return nAvailable;
|
return nAvailable;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -579,7 +631,7 @@ public class DomainSocket implements Closeable {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(int val) throws IOException {
|
public void write(int val) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
byte b[] = new byte[1];
|
byte b[] = new byte[1];
|
||||||
|
@ -587,19 +639,19 @@ public class DomainSocket implements Closeable {
|
||||||
DomainSocket.writeArray0(DomainSocket.this.fd, b, 0, 1);
|
DomainSocket.writeArray0(DomainSocket.this.fd, b, 0, 1);
|
||||||
exc = false;
|
exc = false;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(byte[] b, int off, int len) throws IOException {
|
public void write(byte[] b, int off, int len) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
DomainSocket.writeArray0(DomainSocket.this.fd, b, off, len);
|
DomainSocket.writeArray0(DomainSocket.this.fd, b, off, len);
|
||||||
exc = false;
|
exc = false;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -618,7 +670,7 @@ public class DomainSocket implements Closeable {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int read(ByteBuffer dst) throws IOException {
|
public int read(ByteBuffer dst) throws IOException {
|
||||||
fdRef();
|
status.reference();
|
||||||
boolean exc = true;
|
boolean exc = true;
|
||||||
try {
|
try {
|
||||||
int nread = 0;
|
int nread = 0;
|
||||||
|
@ -640,7 +692,7 @@ public class DomainSocket implements Closeable {
|
||||||
exc = false;
|
exc = false;
|
||||||
return nread;
|
return nread;
|
||||||
} finally {
|
} finally {
|
||||||
fdUnref(exc);
|
status.unreference(exc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,13 +38,13 @@
|
||||||
#include <sys/un.h>
|
#include <sys/un.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#define SND_BUF_SIZE org_apache_hadoop_net_unix_DomainSocket_SND_BUF_SIZE
|
#define SEND_BUFFER_SIZE org_apache_hadoop_net_unix_DomainSocket_SEND_BUFFER_SIZE
|
||||||
#define RCV_BUF_SIZE org_apache_hadoop_net_unix_DomainSocket_RCV_BUF_SIZE
|
#define RECEIVE_BUFFER_SIZE org_apache_hadoop_net_unix_DomainSocket_RECEIVE_BUFFER_SIZE
|
||||||
#define SND_TIMEO org_apache_hadoop_net_unix_DomainSocket_SND_TIMEO
|
#define SEND_TIMEOUT org_apache_hadoop_net_unix_DomainSocket_SEND_TIMEOUT
|
||||||
#define RCV_TIMEO org_apache_hadoop_net_unix_DomainSocket_RCV_TIMEO
|
#define RECEIVE_TIMEOUT org_apache_hadoop_net_unix_DomainSocket_RECEIVE_TIMEOUT
|
||||||
|
|
||||||
#define DEFAULT_RCV_TIMEO 120000
|
#define DEFAULT_RECEIVE_TIMEOUT 120000
|
||||||
#define DEFAULT_SND_TIMEO 120000
|
#define DEFAULT_SEND_TIMEOUT 120000
|
||||||
#define LISTEN_BACKLOG 128
|
#define LISTEN_BACKLOG 128
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -391,8 +391,8 @@ JNIEnv *env, jclass clazz, jstring path)
|
||||||
(*env)->Throw(env, jthr);
|
(*env)->Throw(env, jthr);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (((jthr = setAttribute0(env, fd, SND_TIMEO, DEFAULT_SND_TIMEO))) ||
|
if (((jthr = setAttribute0(env, fd, SEND_TIMEOUT, DEFAULT_SEND_TIMEOUT))) ||
|
||||||
((jthr = setAttribute0(env, fd, RCV_TIMEO, DEFAULT_RCV_TIMEO)))) {
|
((jthr = setAttribute0(env, fd, RECEIVE_TIMEOUT, DEFAULT_RECEIVE_TIMEOUT)))) {
|
||||||
RETRY_ON_EINTR(ret, close(fd));
|
RETRY_ON_EINTR(ret, close(fd));
|
||||||
(*env)->Throw(env, jthr);
|
(*env)->Throw(env, jthr);
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -412,7 +412,7 @@ static jthrowable setAttribute0(JNIEnv *env, jint fd, jint type, jint val)
|
||||||
int ret, buf;
|
int ret, buf;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case SND_BUF_SIZE:
|
case SEND_BUFFER_SIZE:
|
||||||
buf = val;
|
buf = val;
|
||||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &buf, sizeof(buf))) {
|
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &buf, sizeof(buf))) {
|
||||||
ret = errno;
|
ret = errno;
|
||||||
|
@ -420,7 +420,7 @@ static jthrowable setAttribute0(JNIEnv *env, jint fd, jint type, jint val)
|
||||||
"setsockopt(SO_SNDBUF) error: %s", terror(ret));
|
"setsockopt(SO_SNDBUF) error: %s", terror(ret));
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
case RCV_BUF_SIZE:
|
case RECEIVE_BUFFER_SIZE:
|
||||||
buf = val;
|
buf = val;
|
||||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &buf, sizeof(buf))) {
|
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &buf, sizeof(buf))) {
|
||||||
ret = errno;
|
ret = errno;
|
||||||
|
@ -428,7 +428,7 @@ static jthrowable setAttribute0(JNIEnv *env, jint fd, jint type, jint val)
|
||||||
"setsockopt(SO_RCVBUF) error: %s", terror(ret));
|
"setsockopt(SO_RCVBUF) error: %s", terror(ret));
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
case SND_TIMEO:
|
case SEND_TIMEOUT:
|
||||||
javaMillisToTimeVal(val, &tv);
|
javaMillisToTimeVal(val, &tv);
|
||||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, (struct timeval *)&tv,
|
if (setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, (struct timeval *)&tv,
|
||||||
sizeof(tv))) {
|
sizeof(tv))) {
|
||||||
|
@ -437,7 +437,7 @@ static jthrowable setAttribute0(JNIEnv *env, jint fd, jint type, jint val)
|
||||||
"setsockopt(SO_SNDTIMEO) error: %s", terror(ret));
|
"setsockopt(SO_SNDTIMEO) error: %s", terror(ret));
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
case RCV_TIMEO:
|
case RECEIVE_TIMEOUT:
|
||||||
javaMillisToTimeVal(val, &tv);
|
javaMillisToTimeVal(val, &tv);
|
||||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, (struct timeval *)&tv,
|
if (setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, (struct timeval *)&tv,
|
||||||
sizeof(tv))) {
|
sizeof(tv))) {
|
||||||
|
@ -487,7 +487,7 @@ JNIEnv *env, jclass clazz, jint fd, jint type)
|
||||||
int ret, rval = 0;
|
int ret, rval = 0;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case SND_BUF_SIZE:
|
case SEND_BUFFER_SIZE:
|
||||||
len = sizeof(rval);
|
len = sizeof(rval);
|
||||||
if (getsockopt(fd, SOL_SOCKET, SO_SNDBUF, &rval, &len)) {
|
if (getsockopt(fd, SOL_SOCKET, SO_SNDBUF, &rval, &len)) {
|
||||||
ret = errno;
|
ret = errno;
|
||||||
|
@ -496,7 +496,7 @@ JNIEnv *env, jclass clazz, jint fd, jint type)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return getSockOptBufSizeToJavaBufSize(rval);
|
return getSockOptBufSizeToJavaBufSize(rval);
|
||||||
case RCV_BUF_SIZE:
|
case RECEIVE_BUFFER_SIZE:
|
||||||
len = sizeof(rval);
|
len = sizeof(rval);
|
||||||
if (getsockopt(fd, SOL_SOCKET, SO_RCVBUF, &rval, &len)) {
|
if (getsockopt(fd, SOL_SOCKET, SO_RCVBUF, &rval, &len)) {
|
||||||
ret = errno;
|
ret = errno;
|
||||||
|
@ -505,7 +505,7 @@ JNIEnv *env, jclass clazz, jint fd, jint type)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return getSockOptBufSizeToJavaBufSize(rval);
|
return getSockOptBufSizeToJavaBufSize(rval);
|
||||||
case SND_TIMEO:
|
case SEND_TIMEOUT:
|
||||||
memset(&tv, 0, sizeof(tv));
|
memset(&tv, 0, sizeof(tv));
|
||||||
len = sizeof(struct timeval);
|
len = sizeof(struct timeval);
|
||||||
if (getsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, &tv, &len)) {
|
if (getsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, &tv, &len)) {
|
||||||
|
@ -515,7 +515,7 @@ JNIEnv *env, jclass clazz, jint fd, jint type)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return timeValToJavaMillis(&tv);
|
return timeValToJavaMillis(&tv);
|
||||||
case RCV_TIMEO:
|
case RECEIVE_TIMEOUT:
|
||||||
memset(&tv, 0, sizeof(tv));
|
memset(&tv, 0, sizeof(tv));
|
||||||
len = sizeof(struct timeval);
|
len = sizeof(struct timeval);
|
||||||
if (getsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, &tv, &len)) {
|
if (getsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, &tv, &len)) {
|
||||||
|
|
|
@ -282,15 +282,15 @@ public class TestDomainSocket {
|
||||||
DomainSocket serv = DomainSocket.bindAndListen(TEST_PATH);
|
DomainSocket serv = DomainSocket.bindAndListen(TEST_PATH);
|
||||||
try {
|
try {
|
||||||
// Let's set a new receive buffer size
|
// Let's set a new receive buffer size
|
||||||
int bufSize = serv.getAttribute(DomainSocket.RCV_BUF_SIZE);
|
int bufSize = serv.getAttribute(DomainSocket.RECEIVE_BUFFER_SIZE);
|
||||||
int newBufSize = bufSize / 2;
|
int newBufSize = bufSize / 2;
|
||||||
serv.setAttribute(DomainSocket.RCV_BUF_SIZE, newBufSize);
|
serv.setAttribute(DomainSocket.RECEIVE_BUFFER_SIZE, newBufSize);
|
||||||
int nextBufSize = serv.getAttribute(DomainSocket.RCV_BUF_SIZE);
|
int nextBufSize = serv.getAttribute(DomainSocket.RECEIVE_BUFFER_SIZE);
|
||||||
Assert.assertEquals(newBufSize, nextBufSize);
|
Assert.assertEquals(newBufSize, nextBufSize);
|
||||||
// Let's set a server timeout
|
// Let's set a server timeout
|
||||||
int newTimeout = 1000;
|
int newTimeout = 1000;
|
||||||
serv.setAttribute(DomainSocket.RCV_TIMEO, newTimeout);
|
serv.setAttribute(DomainSocket.RECEIVE_TIMEOUT, newTimeout);
|
||||||
int nextTimeout = serv.getAttribute(DomainSocket.RCV_TIMEO);
|
int nextTimeout = serv.getAttribute(DomainSocket.RECEIVE_TIMEOUT);
|
||||||
Assert.assertEquals(newTimeout, nextTimeout);
|
Assert.assertEquals(newTimeout, nextTimeout);
|
||||||
try {
|
try {
|
||||||
serv.accept();
|
serv.accept();
|
||||||
|
|
|
@ -47,3 +47,5 @@ HDFS-4485. DN should chmod socket path a+w. (Colin Patrick McCabe via atm)
|
||||||
HDFS-4453. Make a simple doc to describe the usage and design of the shortcircuit read feature. (Colin Patrick McCabe via atm)
|
HDFS-4453. Make a simple doc to describe the usage and design of the shortcircuit read feature. (Colin Patrick McCabe via atm)
|
||||||
|
|
||||||
HDFS-4496. DFSClient: don't create a domain socket unless we need it (Colin Patrick McCabe via todd)
|
HDFS-4496. DFSClient: don't create a domain socket unless we need it (Colin Patrick McCabe via todd)
|
||||||
|
|
||||||
|
HDFS-347: style cleanups (Colin Patrick McCabe via atm)
|
||||||
|
|
|
@ -114,7 +114,7 @@ class DomainSocketFactory {
|
||||||
DomainSocket sock = null;
|
DomainSocket sock = null;
|
||||||
try {
|
try {
|
||||||
sock = DomainSocket.connect(escapedPath);
|
sock = DomainSocket.connect(escapedPath);
|
||||||
sock.setAttribute(DomainSocket.RCV_TIMEO, conf.socketTimeout);
|
sock.setAttribute(DomainSocket.RECEIVE_TIMEOUT, conf.socketTimeout);
|
||||||
success = true;
|
success = true;
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
LOG.warn("error creating DomainSocket", e);
|
LOG.warn("error creating DomainSocket", e);
|
||||||
|
|
|
@ -50,12 +50,12 @@ public class DomainPeer implements Peer {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setReadTimeout(int timeoutMs) throws IOException {
|
public void setReadTimeout(int timeoutMs) throws IOException {
|
||||||
socket.setAttribute(DomainSocket.RCV_TIMEO, timeoutMs);
|
socket.setAttribute(DomainSocket.RECEIVE_TIMEOUT, timeoutMs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getReceiveBufferSize() throws IOException {
|
public int getReceiveBufferSize() throws IOException {
|
||||||
return socket.getAttribute(DomainSocket.RCV_BUF_SIZE);
|
return socket.getAttribute(DomainSocket.RECEIVE_BUFFER_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -66,7 +66,7 @@ public class DomainPeer implements Peer {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setWriteTimeout(int timeoutMs) throws IOException {
|
public void setWriteTimeout(int timeoutMs) throws IOException {
|
||||||
socket.setAttribute(DomainSocket.SND_TIMEO, timeoutMs);
|
socket.setAttribute(DomainSocket.SEND_TIMEOUT, timeoutMs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class DomainPeerServer implements PeerServer {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setReceiveBufferSize(int size) throws IOException {
|
public void setReceiveBufferSize(int size) throws IOException {
|
||||||
sock.setAttribute(DomainSocket.RCV_BUF_SIZE, size);
|
sock.setAttribute(DomainSocket.RECEIVE_BUFFER_SIZE, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue