public class org.apache.cassandra.locator.GoogleCloudSnitch extends org.apache.cassandra.locator.AbstractNetworkTopologySnitch
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.cassandra.locator.GoogleCloudSnitch
super_class: org.apache.cassandra.locator.AbstractNetworkTopologySnitch
{
protected static final org.slf4j.Logger logger;
descriptor: Lorg/slf4j/Logger;
flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL
protected static final java.lang.String ZONE_NAME_QUERY_URL;
descriptor: Ljava/lang/String;
flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL
ConstantValue: "http://metadata.google.internal/computeMetadata/v1/instance/zone"
private static final java.lang.String DEFAULT_DC;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "UNKNOWN-DC"
private static final java.lang.String DEFAULT_RACK;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "UNKNOWN-RACK"
private java.util.Map<java.net.InetAddress, java.util.Map<java.lang.String, java.lang.String>> savedEndpoints;
descriptor: Ljava/util/Map;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/Map<Ljava/net/InetAddress;Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;>;
protected java.lang.String gceZone;
descriptor: Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
protected java.lang.String gceRegion;
descriptor: Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/apache/cassandra/locator/GoogleCloudSnitch;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic org.apache.cassandra.locator.GoogleCloudSnitch.logger:Lorg/slf4j/Logger;
1: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=1
start local 0 0: aload 0
invokespecial org.apache.cassandra.locator.AbstractNetworkTopologySnitch.<init>:()V
1: aload 0
ldc "http://metadata.google.internal/computeMetadata/v1/instance/zone"
invokevirtual org.apache.cassandra.locator.GoogleCloudSnitch.gceApiCall:(Ljava/lang/String;)Ljava/lang/String;
astore 1
start local 1 2: aload 1
ldc "/"
invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
astore 2
start local 2 3: aload 2
aload 2
arraylength
iconst_1
isub
aaload
astore 3
start local 3 4: aload 3
ldc "-"
invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
astore 2
5: aload 0
aload 2
aload 2
arraylength
iconst_1
isub
aaload
putfield org.apache.cassandra.locator.GoogleCloudSnitch.gceZone:Ljava/lang/String;
6: aload 3
ldc "-"
invokevirtual java.lang.String.lastIndexOf:(Ljava/lang/String;)I
istore 4
start local 4 7: aload 0
aload 3
iconst_0
iload 4
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
putfield org.apache.cassandra.locator.GoogleCloudSnitch.gceRegion:Ljava/lang/String;
8: new org.apache.cassandra.locator.SnitchProperties
dup
invokespecial org.apache.cassandra.locator.SnitchProperties.<init>:()V
ldc "dc_suffix"
ldc ""
invokevirtual org.apache.cassandra.locator.SnitchProperties.get:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
astore 5
start local 5 9: aload 0
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.gceRegion:Ljava/lang/String;
aload 5
invokevirtual java.lang.String.concat:(Ljava/lang/String;)Ljava/lang/String;
putfield org.apache.cassandra.locator.GoogleCloudSnitch.gceRegion:Ljava/lang/String;
10: getstatic org.apache.cassandra.locator.GoogleCloudSnitch.logger:Lorg/slf4j/Logger;
ldc "GCESnitch using region: {}, zone: {}."
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.gceRegion:Ljava/lang/String;
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.gceZone:Ljava/lang/String;
invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
11: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/cassandra/locator/GoogleCloudSnitch;
2 12 1 response Ljava/lang/String;
3 12 2 splits [Ljava/lang/String;
4 12 3 az Ljava/lang/String;
7 12 4 lastRegionIndex I
9 12 5 datacenterSuffix Ljava/lang/String;
Exceptions:
throws java.io.IOException, org.apache.cassandra.exceptions.ConfigurationException
java.lang.String gceApiCall(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0000)
Code:
stack=4, locals=8, args_size=2
start local 0 start local 1 0: new java.net.URL
dup
aload 1
invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
invokevirtual java.net.URL.openConnection:()Ljava/net/URLConnection;
checkcast java.net.HttpURLConnection
astore 2
start local 2 1: aconst_null
astore 3
start local 3 2: aload 2
ldc "GET"
invokevirtual java.net.HttpURLConnection.setRequestMethod:(Ljava/lang/String;)V
3: aload 2
ldc "Metadata-Flavor"
ldc "Google"
invokevirtual java.net.HttpURLConnection.setRequestProperty:(Ljava/lang/String;Ljava/lang/String;)V
4: aload 2
invokevirtual java.net.HttpURLConnection.getResponseCode:()I
sipush 200
if_icmpeq 6
5: new org.apache.cassandra.exceptions.ConfigurationException
dup
ldc "GoogleCloudSnitch was unable to execute the API call. Not a gce node?"
invokespecial org.apache.cassandra.exceptions.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals: java.net.HttpURLConnection java.io.DataInputStream
StackMap stack:
aload 2
invokevirtual java.net.HttpURLConnection.getContentLength:()I
istore 4
start local 4 7: iload 4
newarray 8
astore 5
start local 5 8: new java.io.DataInputStream
dup
aload 2
invokevirtual java.net.HttpURLConnection.getContent:()Ljava/lang/Object;
checkcast java.io.FilterInputStream
invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
astore 3
9: aload 3
aload 5
invokevirtual java.io.DataInputStream.readFully:([B)V
10: new java.lang.String
dup
aload 5
getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
invokespecial java.lang.String.<init>:([BLjava/nio/charset/Charset;)V
astore 7
11: iconst_1
anewarray java.io.Closeable
dup
iconst_0
12: aload 3
aastore
invokestatic org.apache.cassandra.io.util.FileUtils.close:([Ljava/io/Closeable;)V
13: aload 2
invokevirtual java.net.HttpURLConnection.disconnect:()V
14: aload 7
areturn
end local 5 end local 4 15: StackMap locals:
StackMap stack: java.lang.Throwable
astore 6
iconst_1
anewarray java.io.Closeable
dup
iconst_0
16: aload 3
aastore
invokestatic org.apache.cassandra.io.util.FileUtils.close:([Ljava/io/Closeable;)V
17: aload 2
invokevirtual java.net.HttpURLConnection.disconnect:()V
18: aload 6
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lorg/apache/cassandra/locator/GoogleCloudSnitch;
0 19 1 url Ljava/lang/String;
1 19 2 conn Ljava/net/HttpURLConnection;
2 19 3 d Ljava/io/DataInputStream;
7 15 4 cl I
8 15 5 b [B
Exception table:
from to target type
2 11 15 any
Exceptions:
throws java.io.IOException, org.apache.cassandra.exceptions.ConfigurationException
MethodParameters:
Name Flags
url
public java.lang.String getRack(java.net.InetAddress);
descriptor: (Ljava/net/InetAddress;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
ifeq 2
1: aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.gceZone:Ljava/lang/String;
areturn
2: StackMap locals:
StackMap stack:
getstatic org.apache.cassandra.gms.Gossiper.instance:Lorg/apache/cassandra/gms/Gossiper;
aload 1
invokevirtual org.apache.cassandra.gms.Gossiper.getEndpointStateForEndpoint:(Ljava/net/InetAddress;)Lorg/apache/cassandra/gms/EndpointState;
astore 2
start local 2 3: aload 2
ifnull 4
aload 2
getstatic org.apache.cassandra.gms.ApplicationState.RACK:Lorg/apache/cassandra/gms/ApplicationState;
invokevirtual org.apache.cassandra.gms.EndpointState.getApplicationState:(Lorg/apache/cassandra/gms/ApplicationState;)Lorg/apache/cassandra/gms/VersionedValue;
ifnonnull 9
4: StackMap locals: org.apache.cassandra.gms.EndpointState
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
ifnonnull 6
5: aload 0
invokestatic org.apache.cassandra.db.SystemKeyspace.loadDcRackInfo:()Ljava/util/Map;
putfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
6: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
ifeq 8
7: aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.Map
ldc "rack"
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.String
areturn
8: StackMap locals:
StackMap stack:
ldc "UNKNOWN-RACK"
areturn
9: StackMap locals:
StackMap stack:
aload 2
getstatic org.apache.cassandra.gms.ApplicationState.RACK:Lorg/apache/cassandra/gms/ApplicationState;
invokevirtual org.apache.cassandra.gms.EndpointState.getApplicationState:(Lorg/apache/cassandra/gms/ApplicationState;)Lorg/apache/cassandra/gms/VersionedValue;
getfield org.apache.cassandra.gms.VersionedValue.value:Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/locator/GoogleCloudSnitch;
0 10 1 endpoint Ljava/net/InetAddress;
3 10 2 state Lorg/apache/cassandra/gms/EndpointState;
MethodParameters:
Name Flags
endpoint
public java.lang.String getDatacenter(java.net.InetAddress);
descriptor: (Ljava/net/InetAddress;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.apache.cassandra.utils.FBUtilities.getBroadcastAddress:()Ljava/net/InetAddress;
invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
ifeq 2
1: aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.gceRegion:Ljava/lang/String;
areturn
2: StackMap locals:
StackMap stack:
getstatic org.apache.cassandra.gms.Gossiper.instance:Lorg/apache/cassandra/gms/Gossiper;
aload 1
invokevirtual org.apache.cassandra.gms.Gossiper.getEndpointStateForEndpoint:(Ljava/net/InetAddress;)Lorg/apache/cassandra/gms/EndpointState;
astore 2
start local 2 3: aload 2
ifnull 4
aload 2
getstatic org.apache.cassandra.gms.ApplicationState.DC:Lorg/apache/cassandra/gms/ApplicationState;
invokevirtual org.apache.cassandra.gms.EndpointState.getApplicationState:(Lorg/apache/cassandra/gms/ApplicationState;)Lorg/apache/cassandra/gms/VersionedValue;
ifnonnull 9
4: StackMap locals: org.apache.cassandra.gms.EndpointState
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
ifnonnull 6
5: aload 0
invokestatic org.apache.cassandra.db.SystemKeyspace.loadDcRackInfo:()Ljava/util/Map;
putfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
6: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
ifeq 8
7: aload 0
getfield org.apache.cassandra.locator.GoogleCloudSnitch.savedEndpoints:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.Map
ldc "data_center"
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.String
areturn
8: StackMap locals:
StackMap stack:
ldc "UNKNOWN-DC"
areturn
9: StackMap locals:
StackMap stack:
aload 2
getstatic org.apache.cassandra.gms.ApplicationState.DC:Lorg/apache/cassandra/gms/ApplicationState;
invokevirtual org.apache.cassandra.gms.EndpointState.getApplicationState:(Lorg/apache/cassandra/gms/ApplicationState;)Lorg/apache/cassandra/gms/VersionedValue;
getfield org.apache.cassandra.gms.VersionedValue.value:Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/cassandra/locator/GoogleCloudSnitch;
0 10 1 endpoint Ljava/net/InetAddress;
3 10 2 state Lorg/apache/cassandra/gms/EndpointState;
MethodParameters:
Name Flags
endpoint
}
SourceFile: "GoogleCloudSnitch.java"