NamedPipeSocket Class — spring-boot Architecture
Architecture documentation for the NamedPipeSocket class in NamedPipeSocket.java from the spring-boot codebase.
Entity Profile
Relationship Graph
Source Code
buildpack/spring-boot-buildpack-platform/src/main/java/org/springframework/boot/buildpack/platform/socket/NamedPipeSocket.java lines 48–223
public class NamedPipeSocket extends Socket {
private static final int WAIT_INTERVAL = 100;
private static final long TIMEOUT = TimeUnit.MILLISECONDS.toNanos(1000);
private final AsynchronousFileByteChannel channel;
NamedPipeSocket(String path) throws IOException {
this.channel = open(path);
}
private AsynchronousFileByteChannel open(String path) throws IOException {
Consumer<String> awaiter = Platform.isWindows() ? new WindowsAwaiter() : new SleepAwaiter();
long startTime = System.nanoTime();
while (true) {
try {
return new AsynchronousFileByteChannel(AsynchronousFileChannel.open(Paths.get(path),
StandardOpenOption.READ, StandardOpenOption.WRITE));
}
catch (FileSystemException ex) {
if (System.nanoTime() - startTime >= TIMEOUT) {
throw ex;
}
awaiter.accept(path);
}
}
}
@Override
public void connect(SocketAddress endpoint) throws IOException {
// No-op
}
@Override
public void connect(SocketAddress endpoint, int timeout) throws IOException {
// No-op
}
@Override
public InputStream getInputStream() {
return Channels.newInputStream(this.channel);
}
@Override
public OutputStream getOutputStream() {
return Channels.newOutputStream(this.channel);
}
@Override
public void close() throws IOException {
if (this.channel != null) {
this.channel.close();
}
}
/**
* Return a new {@link NamedPipeSocket} for the given path.
* @param path the path to the domain socket
* @return a {@link NamedPipeSocket} instance
* @throws IOException if the socket cannot be opened
*/
public static NamedPipeSocket get(String path) throws IOException {
return new NamedPipeSocket(path);
}
/**
* Adapt an {@code AsynchronousByteChannel} to an {@code AsynchronousFileChannel}.
*/
private static class AsynchronousFileByteChannel implements AsynchronousByteChannel {
private final AsynchronousFileChannel fileChannel;
AsynchronousFileByteChannel(AsynchronousFileChannel fileChannel) {
this.fileChannel = fileChannel;
}
@Override
public <A> void read(ByteBuffer dst, A attachment, CompletionHandler<Integer, ? super A> handler) {
this.fileChannel.read(dst, 0, attachment, new CompletionHandler<>() {
@Override
public void completed(Integer read, A attachment) {
handler.completed((read > 0) ? read : -1, attachment);
}
@Override
public void failed(Throwable exc, A attachment) {
if (exc instanceof AsynchronousCloseException) {
handler.completed(-1, attachment);
return;
}
handler.failed(exc, attachment);
}
});
}
@Override
public Future<Integer> read(ByteBuffer dst) {
CompletableFutureHandler future = new CompletableFutureHandler();
this.fileChannel.read(dst, 0, null, future);
return future;
}
@Override
public <A> void write(ByteBuffer src, A attachment, CompletionHandler<Integer, ? super A> handler) {
this.fileChannel.write(src, 0, attachment, handler);
}
@Override
public Future<Integer> write(ByteBuffer src) {
return this.fileChannel.write(src, 0);
}
@Override
public void close() throws IOException {
this.fileChannel.close();
}
@Override
public boolean isOpen() {
return this.fileChannel.isOpen();
}
private static final class CompletableFutureHandler extends CompletableFuture<Integer>
implements CompletionHandler<Integer, Object> {
@Override
public void completed(Integer read, Object attachment) {
complete((read > 0) ? read : -1);
}
@Override
public void failed(Throwable exc, Object attachment) {
if (exc instanceof AsynchronousCloseException) {
complete(-1);
return;
}
completeExceptionally(exc);
}
}
}
/**
* Waits for the name pipe file using a simple sleep.
*/
private static final class SleepAwaiter implements Consumer<String> {
@Override
public void accept(String path) {
try {
Thread.sleep(WAIT_INTERVAL);
}
catch (InterruptedException ex) {
Thread.currentThread().interrupt();
}
}
}
/**
* Waits for the name pipe file using Windows specific logic.
*/
private static final class WindowsAwaiter implements Consumer<String> {
@Override
public void accept(String path) {
Kernel32.INSTANCE.WaitNamedPipe(path, WAIT_INTERVAL);
}
}
}
Domain
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free