public class org.apache.cassandra.net.MessagingService$SocketThread extends java.lang.Thread
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.cassandra.net.MessagingService$SocketThread
super_class: java.lang.Thread
{
private final java.net.ServerSocket server;
descriptor: Ljava/net/ServerSocket;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
public final java.util.Set<java.io.Closeable> connections;
descriptor: Ljava/util/Set;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Signature: Ljava/util/Set<Ljava/io/Closeable;>;
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()
void <init>(java.net.ServerSocket, java.lang.String);
descriptor: (Ljava/net/ServerSocket;Ljava/lang/String;)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 2
invokespecial java.lang.Thread.<init>:(Ljava/lang/String;)V
1: aload 0
invokestatic com.google.common.collect.Sets.newConcurrentHashSet:()Ljava/util/Set;
putfield org.apache.cassandra.net.MessagingService$SocketThread.connections:Ljava/util/Set;
2: aload 0
aload 1
putfield org.apache.cassandra.net.MessagingService$SocketThread.server:Ljava/net/ServerSocket;
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/cassandra/net/MessagingService$SocketThread;
0 4 1 server Ljava/net/ServerSocket;
0 4 2 name Ljava/lang/String;
MethodParameters:
Name Flags
server
name
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=7, args_size=1
start local 0 0: goto 40
1: StackMap locals:
StackMap stack:
aconst_null
astore 1
start local 1 2: aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.server:Ljava/net/ServerSocket;
invokevirtual java.net.ServerSocket.accept:()Ljava/net/Socket;
astore 1
3: aload 0
aload 1
invokevirtual org.apache.cassandra.net.MessagingService$SocketThread.authenticate:(Ljava/net/Socket;)Z
ifne 7
4: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "remote failed to authenticate"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
5: aload 1
invokevirtual java.net.Socket.close:()V
6: goto 40
7: StackMap locals: java.net.Socket
StackMap stack:
aload 1
iconst_1
invokevirtual java.net.Socket.setKeepAlive:(Z)V
8: aload 1
sipush 10000
invokevirtual java.net.Socket.setSoTimeout:(I)V
9: new java.io.DataInputStream
dup
aload 1
invokevirtual java.net.Socket.getInputStream:()Ljava/io/InputStream;
invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
astore 2
start local 2 10: aload 2
invokevirtual java.io.DataInputStream.readInt:()I
invokestatic org.apache.cassandra.net.MessagingService.validateMagic:(I)V
11: aload 2
invokevirtual java.io.DataInputStream.readInt:()I
istore 3
start local 3 12: iload 3
iconst_3
iconst_1
invokestatic org.apache.cassandra.net.MessagingService.getBits:(III)I
iconst_1
if_icmpne 13
iconst_1
goto 14
StackMap locals: java.io.DataInputStream int
StackMap stack:
13: iconst_0
StackMap locals:
StackMap stack: int
14: istore 4
start local 4 15: iload 3
bipush 15
bipush 8
invokestatic org.apache.cassandra.net.MessagingService.getBits:(III)I
istore 5
start local 5 16: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "Connection version {} from {}"
iload 5
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 1
invokevirtual java.net.Socket.getInetAddress:()Ljava/net/InetAddress;
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
17: aload 1
iconst_0
invokevirtual java.net.Socket.setSoTimeout:(I)V
18: iload 4
ifeq 20
19: new org.apache.cassandra.net.IncomingStreamingConnection
dup
iload 5
aload 1
aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.connections:Ljava/util/Set;
invokespecial org.apache.cassandra.net.IncomingStreamingConnection.<init>:(ILjava/net/Socket;Ljava/util/Set;)V
goto 23
20: StackMap locals: int int
StackMap stack:
new org.apache.cassandra.net.IncomingTcpConnection
dup
iload 5
iload 3
iconst_2
iconst_1
invokestatic org.apache.cassandra.net.MessagingService.getBits:(III)I
iconst_1
if_icmpne 21
iconst_1
goto 22
StackMap locals: org.apache.cassandra.net.MessagingService$SocketThread java.net.Socket java.io.DataInputStream int int int
StackMap stack: new 20 new 20 int
21: iconst_0
StackMap locals: org.apache.cassandra.net.MessagingService$SocketThread java.net.Socket java.io.DataInputStream int int int
StackMap stack: new 20 new 20 int int
22: aload 1
aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.connections:Ljava/util/Set;
invokespecial org.apache.cassandra.net.IncomingTcpConnection.<init>:(IZLjava/net/Socket;Ljava/util/Set;)V
23: StackMap locals:
StackMap stack: java.lang.Thread
astore 6
start local 6 24: aload 6
invokevirtual java.lang.Thread.start:()V
25: aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.connections:Ljava/util/Set;
aload 6
checkcast java.io.Closeable
invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
pop
end local 6 end local 5 end local 4 end local 3 end local 2 26: goto 40
27: StackMap locals: org.apache.cassandra.net.MessagingService$SocketThread java.net.Socket
StackMap stack: java.nio.channels.AsynchronousCloseException
pop
28: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "Asynchronous close seen by server thread"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
29: goto 41
30: StackMap locals:
StackMap stack: java.nio.channels.ClosedChannelException
pop
31: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "MessagingService server thread already closed"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
32: goto 41
33: StackMap locals:
StackMap stack: javax.net.ssl.SSLHandshakeException
astore 2
start local 2 34: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
new java.lang.StringBuilder
dup
ldc "SSL handshake error for inbound connection from "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 2
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
35: aload 1
invokestatic org.apache.cassandra.io.util.FileUtils.closeQuietly:(Ljava/io/Closeable;)V
end local 2 36: goto 40
37: StackMap locals:
StackMap stack: java.lang.Throwable
astore 2
start local 2 38: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "Error reading the socket {}"
aload 1
aload 2
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
39: aload 1
invokestatic org.apache.cassandra.io.util.FileUtils.closeQuietly:(Ljava/io/Closeable;)V
end local 2 end local 1 40: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.server:Ljava/net/ServerSocket;
invokevirtual java.net.ServerSocket.isClosed:()Z
ifeq 1
41: StackMap locals:
StackMap stack:
getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "MessagingService has terminated the accept() thread"
invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
42: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 43 0 this Lorg/apache/cassandra/net/MessagingService$SocketThread;
2 40 1 socket Ljava/net/Socket;
10 26 2 in Ljava/io/DataInputStream;
12 26 3 header I
15 26 4 isStream Z
16 26 5 version I
24 26 6 thread Ljava/lang/Thread;
34 36 2 e Ljavax/net/ssl/SSLHandshakeException;
38 40 2 t Ljava/lang/Throwable;
Exception table:
from to target type
2 6 27 Class java.nio.channels.AsynchronousCloseException
7 26 27 Class java.nio.channels.AsynchronousCloseException
2 6 30 Class java.nio.channels.ClosedChannelException
7 26 30 Class java.nio.channels.ClosedChannelException
2 6 33 Class javax.net.ssl.SSLHandshakeException
7 26 33 Class javax.net.ssl.SSLHandshakeException
2 6 37 Class java.lang.Throwable
7 26 37 Class java.lang.Throwable
void close();
descriptor: ()V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=1
start local 0 0: getstatic org.apache.cassandra.net.MessagingService.logger:Lorg/slf4j/Logger;
ldc "Closing accept() thread"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
1: aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.server:Ljava/net/ServerSocket;
invokevirtual java.net.ServerSocket.close:()V
2: goto 5
3: StackMap locals:
StackMap stack: java.io.IOException
astore 1
start local 1 4: aload 1
invokestatic org.apache.cassandra.net.MessagingService.handleIOExceptionOnClose:(Ljava/io/IOException;)V
end local 1 5: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.net.MessagingService$SocketThread.connections:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 2
goto 8
StackMap locals: org.apache.cassandra.net.MessagingService$SocketThread top java.util.Iterator
StackMap stack:
6: aload 2
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.io.Closeable
astore 1
start local 1 7: aload 1
invokeinterface java.io.Closeable.close:()V
end local 1 8: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.util.Iterator.hasNext:()Z
ifne 6
9: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/net/MessagingService$SocketThread;
4 5 1 e Ljava/io/IOException;
7 8 1 connection Ljava/io/Closeable;
Exception table:
from to target type
1 2 3 Class java.io.IOException
Exceptions:
throws java.io.IOException
private boolean authenticate(java.net.Socket);
descriptor: (Ljava/net/Socket;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: invokestatic org.apache.cassandra.config.DatabaseDescriptor.getInternodeAuthenticator:()Lorg/apache/cassandra/auth/IInternodeAuthenticator;
aload 1
invokevirtual java.net.Socket.getInetAddress:()Ljava/net/InetAddress;
aload 1
invokevirtual java.net.Socket.getPort:()I
invokeinterface org.apache.cassandra.auth.IInternodeAuthenticator.authenticate:(Ljava/net/InetAddress;I)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/net/MessagingService$SocketThread;
0 1 1 socket Ljava/net/Socket;
MethodParameters:
Name Flags
socket
}
SourceFile: "MessagingService.java"
NestHost: org.apache.cassandra.net.MessagingService
InnerClasses:
public SocketThread = org.apache.cassandra.net.MessagingService$SocketThread of org.apache.cassandra.net.MessagingService
RuntimeInvisibleAnnotations:
com.google.common.annotations.VisibleForTesting()