public class io.ebeaninternal.server.transaction.DefaultProfileHandler implements io.ebeaninternal.api.SpiProfileHandler, io.ebean.plugin.Plugin
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: io.ebeaninternal.server.transaction.DefaultProfileHandler
super_class: java.lang.Object
{
private static final org.slf4j.Logger log;
descriptor: Lorg/slf4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.time.format.DateTimeFormatter DTF;
descriptor: Ljava/time/format/DateTimeFormatter;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final java.util.Queue<io.ebeaninternal.server.transaction.TransactionProfile> queue;
descriptor: Ljava/util/Queue;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Queue<Lio/ebeaninternal/server/transaction/TransactionProfile;>;
private final java.util.concurrent.ExecutorService executor;
descriptor: Ljava/util/concurrent/ExecutorService;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.ReentrantLock lock;
descriptor: Ljava/util/concurrent/locks/ReentrantLock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.io.File dir;
descriptor: Ljava/io/File;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final long minMicros;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final long profilesPerFile;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final boolean verbose;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private volatile boolean shutdown;
descriptor: Z
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private long profileCounter;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private int sleepBackoff;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private java.io.Writer out;
descriptor: Ljava/io/Writer;
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: ldc Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
1: new java.time.format.DateTimeFormatterBuilder
dup
invokespecial java.time.format.DateTimeFormatterBuilder.<init>:()V
2: invokevirtual java.time.format.DateTimeFormatterBuilder.parseCaseInsensitive:()Ljava/time/format/DateTimeFormatterBuilder;
3: getstatic java.time.temporal.ChronoField.YEAR:Ljava/time/temporal/ChronoField;
iconst_4
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
4: getstatic java.time.temporal.ChronoField.MONTH_OF_YEAR:Ljava/time/temporal/ChronoField;
iconst_2
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
5: getstatic java.time.temporal.ChronoField.DAY_OF_MONTH:Ljava/time/temporal/ChronoField;
iconst_2
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
6: bipush 45
invokevirtual java.time.format.DateTimeFormatterBuilder.appendLiteral:(C)Ljava/time/format/DateTimeFormatterBuilder;
7: getstatic java.time.temporal.ChronoField.HOUR_OF_DAY:Ljava/time/temporal/ChronoField;
iconst_2
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
8: getstatic java.time.temporal.ChronoField.MINUTE_OF_HOUR:Ljava/time/temporal/ChronoField;
iconst_2
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
9: getstatic java.time.temporal.ChronoField.SECOND_OF_MINUTE:Ljava/time/temporal/ChronoField;
iconst_2
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
10: bipush 45
invokevirtual java.time.format.DateTimeFormatterBuilder.appendLiteral:(C)Ljava/time/format/DateTimeFormatterBuilder;
11: getstatic java.time.temporal.ChronoField.MILLI_OF_SECOND:Ljava/time/temporal/ChronoField;
iconst_3
invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
12: invokevirtual java.time.format.DateTimeFormatterBuilder.toFormatter:()Ljava/time/format/DateTimeFormatter;
13: putstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.DTF:Ljava/time/format/DateTimeFormatter;
14: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(io.ebean.config.ProfilingConfig);
descriptor: (Lio/ebean/config/ProfilingConfig;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.ConcurrentLinkedQueue
dup
invokespecial java.util.concurrent.ConcurrentLinkedQueue.<init>:()V
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
2: aload 0
new java.util.concurrent.locks.ReentrantLock
dup
invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
3: aload 0
aload 1
invokevirtual io.ebean.config.ProfilingConfig.isVerbose:()Z
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
4: aload 0
aload 1
invokevirtual io.ebean.config.ProfilingConfig.getMinimumMicros:()J
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.minMicros:J
5: aload 0
aload 1
invokevirtual io.ebean.config.ProfilingConfig.getProfilesPerFile:()J
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profilesPerFile:J
6: aload 0
invokestatic java.util.concurrent.Executors.newSingleThreadExecutor:()Ljava/util/concurrent/ExecutorService;
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
7: aload 0
new java.io.File
dup
aload 1
invokevirtual io.ebean.config.ProfilingConfig.getDirectory:()Ljava/lang/String;
invokespecial java.io.File.<init>:(Ljava/lang/String;)V
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
8: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
invokevirtual java.io.File.exists:()Z
ifne 10
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
invokevirtual java.io.File.mkdirs:()Z
ifne 10
9: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
new java.lang.StringBuilder
dup
ldc "failed to mkdirs "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;)V
10: StackMap locals: io.ebeaninternal.server.transaction.DefaultProfileHandler io.ebean.config.ProfilingConfig
StackMap stack:
aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.incrementFile:()V
11: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 12 1 config Lio/ebean/config/ProfilingConfig;
MethodParameters:
Name Flags
config
public void collectTransactionProfile(io.ebeaninternal.server.transaction.TransactionProfile);
descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
aload 1
invokeinterface java.util.Queue.add:(Ljava/lang/Object;)Z
pop
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 2 1 transactionProfile Lio/ebeaninternal/server/transaction/TransactionProfile;
MethodParameters:
Name Flags
transactionProfile
public io.ebeaninternal.server.transaction.ProfileStream createProfileStream(io.ebean.ProfileLocation);
descriptor: (Lio/ebean/ProfileLocation;)Lio/ebeaninternal/server/transaction/ProfileStream;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: new io.ebeaninternal.server.transaction.DefaultProfileStream
dup
aload 1
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
invokespecial io.ebeaninternal.server.transaction.DefaultProfileStream.<init>:(Lio/ebean/ProfileLocation;Z)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 1 1 location Lio/ebean/ProfileLocation;
MethodParameters:
Name Flags
location
private void flushCurrentFile();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
ifnull 11
2: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
invokevirtual java.io.Writer.close:()V
3: aload 0
aconst_null
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
4: goto 11
StackMap locals:
StackMap stack: java.io.IOException
5: astore 1
start local 1 6: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Failed to flush and close transaction profiling file "
aload 1
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 1 7: goto 11
StackMap locals:
StackMap stack: java.lang.Throwable
8: astore 2
9: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
10: aload 2
athrow
11: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
12: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
6 7 1 e Ljava/io/IOException;
Exception table:
from to target type
2 4 5 Class java.io.IOException
1 8 8 any
private void incrementFile();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=4, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
2: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.DTF:Ljava/time/format/DateTimeFormatter;
invokestatic java.time.LocalDateTime.now:()Ljava/time/LocalDateTime;
invokevirtual java.time.format.DateTimeFormatter.format:(Ljava/time/temporal/TemporalAccessor;)Ljava/lang/String;
astore 1
start local 1 3: new java.io.File
dup
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
new java.lang.StringBuilder
dup
ldc "txprofile-"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ".tprofile"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
astore 2
start local 2 4: aload 0
new java.io.BufferedWriter
dup
new java.io.FileWriter
dup
aload 2
invokespecial java.io.FileWriter.<init>:(Ljava/io/File;)V
invokespecial java.io.BufferedWriter.<init>:(Ljava/io/Writer;)V
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
end local 2 end local 1 5: goto 12
StackMap locals:
StackMap stack: java.io.IOException
6: astore 1
start local 1 7: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Not expected"
aload 1
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 1 8: goto 12
StackMap locals:
StackMap stack: java.lang.Throwable
9: astore 3
10: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
11: aload 3
athrow
12: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
13: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
3 5 1 now Ljava/lang/String;
4 5 2 file Ljava/io/File;
7 8 1 e Ljava/io/IOException;
Exception table:
from to target type
2 5 6 Class java.io.IOException
1 9 9 any
private void collect();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=1
start local 0 0: goto 7
1: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
checkcast io.ebeaninternal.server.transaction.TransactionProfile
astore 1
start local 1 2: aload 1
ifnonnull 5
3: aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.sleep:()V
4: goto 7
StackMap locals: io.ebeaninternal.server.transaction.TransactionProfile
StackMap stack:
5: aload 0
aload 1
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.include:(Lio/ebeaninternal/server/transaction/TransactionProfile;)Z
ifeq 7
6: aload 0
aload 1
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.write:(Lio/ebeaninternal/server/transaction/TransactionProfile;)V
end local 1 7: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.shutdown:Z
ifeq 1
8: aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
9: goto 12
StackMap locals:
StackMap stack: java.lang.Exception
10: astore 1
start local 1 11: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Error on collect"
aload 1
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 1 12: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
2 7 1 profile Lio/ebeaninternal/server/transaction/TransactionProfile;
11 12 1 e Ljava/lang/Exception;
Exception table:
from to target type
0 9 10 Class java.lang.Exception
private void write(io.ebeaninternal.server.transaction.TransactionProfile);
descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 0
iconst_0
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
1: aload 0
dup
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
lconst_1
ladd
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
2: new java.lang.StringBuilder
dup
bipush 80
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 2
start local 2 3: aload 2
aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getStartTime:()J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
4: aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getLabel:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
5: aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
6: aload 0
aload 1
aload 2
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.appendSummary:(Lio/ebeaninternal/server/transaction/TransactionProfile;Ljava/lang/StringBuilder;)V
7: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
aload 2
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.Writer.write:(Ljava/lang/String;)V
8: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
ifeq 11
9: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
bipush 32
invokevirtual java.io.Writer.write:(I)V
10: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getData:()Ljava/lang/String;
invokevirtual java.io.Writer.write:(Ljava/lang/String;)V
11: StackMap locals: java.lang.StringBuilder
StackMap stack:
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
bipush 10
invokevirtual java.io.Writer.write:(I)V
12: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profilesPerFile:J
lrem
lconst_0
lcmp
ifne 18
13: aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.incrementFile:()V
14: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "profiled {} transactions"
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
end local 2 15: goto 18
StackMap locals: io.ebeaninternal.server.transaction.DefaultProfileHandler io.ebeaninternal.server.transaction.TransactionProfile
StackMap stack: java.io.IOException
16: astore 2
start local 2 17: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Error writing transaction profiling"
aload 2
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 2 18: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 19 1 profile Lio/ebeaninternal/server/transaction/TransactionProfile;
3 15 2 sb Ljava/lang/StringBuilder;
17 18 2 e Ljava/io/IOException;
Exception table:
from to target type
0 15 16 Class java.io.IOException
MethodParameters:
Name Flags
profile
private void appendSummary(io.ebeaninternal.server.transaction.TransactionProfile, java.lang.StringBuilder);
descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;Ljava/lang/StringBuilder;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=8, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getSummary:()Lio/ebeaninternal/server/transaction/TransactionProfile$Summary;
astore 3
start local 3 1: aload 2
ldc "z:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
ladd
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
2: aload 2
ldc "p:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistMicros:J
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
3: aload 2
ldc "q:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMicros:J
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
4: aload 2
ldc "qm:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMax:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
5: aload 2
ldc "qt:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMicros:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
6: aload 2
ldc "qc:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
7: aload 2
ldc "qb:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryBeans:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
8: aload 2
ldc "pt:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistMicros:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
9: aload 2
ldc "pc:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
10: aload 2
ldc "pb:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
11: aload 2
ldc "po:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistOneCount:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
12: aload 2
ldc "pz:"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
aload 3
getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
pop
13: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 14 1 profile Lio/ebeaninternal/server/transaction/TransactionProfile;
0 14 2 sb Ljava/lang/StringBuilder;
1 14 3 summary Lio/ebeaninternal/server/transaction/TransactionProfile$Summary;
MethodParameters:
Name Flags
profile
sb
private int rate(long, long);
descriptor: (JJ)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=5, args_size=3
start local 0 start local 1 start local 3 0: lload 3
lconst_1
lcmp
ifge 1
iconst_0
goto 2
StackMap locals:
StackMap stack:
1: lload 1
lload 3
ldiv
l2i
StackMap locals:
StackMap stack: int
2: ireturn
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 3 1 micros J
0 3 3 count J
MethodParameters:
Name Flags
micros
count
private boolean include(io.ebeaninternal.server.transaction.TransactionProfile);
descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.minMicros:J
lcmp
iflt 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 2 1 profile Lio/ebeaninternal/server/transaction/TransactionProfile;
MethodParameters:
Name Flags
profile
private void sleep();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=1
start local 0 0: aload 0
dup
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
iconst_1
iadd
dup_x1
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
sipush 250
invokestatic java.lang.Math.min:(II)I
istore 1
start local 1 1: iload 1
i2l
invokestatic java.lang.Thread.sleep:(J)V
end local 1 2: goto 5
StackMap locals:
StackMap stack: java.lang.InterruptedException
3: pop
4: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
5: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
1 2 1 sleepFor I
Exception table:
from to target type
0 2 3 Class java.lang.InterruptedException
public void configure(io.ebean.plugin.SpiServer);
descriptor: (Lio/ebean/plugin/SpiServer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=0, locals=2, args_size=2
start local 0 start local 1 0: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 1 1 server Lio/ebean/plugin/SpiServer;
MethodParameters:
Name Flags
server
public void online(boolean);
descriptor: (Z)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 2
1: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
aload 0
invokedynamic run(Lio/ebeaninternal/server/transaction/DefaultProfileHandler;)Ljava/lang/Runnable;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()V
io/ebeaninternal/server/transaction/DefaultProfileHandler.collect()V (7)
()V
invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
pop
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
0 3 1 online Z
MethodParameters:
Name Flags
online
public void shutdown();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=1
start local 0 0: aload 0
iconst_1
putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.shutdown:Z
1: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "shutting down"
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
2: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
3: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
ldc 4
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
invokeinterface java.util.concurrent.ExecutorService.awaitTermination:(JLjava/util/concurrent/TimeUnit;)Z
ifne 10
4: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Shut down timeout exceeded. Terminating profiling consumer thread."
invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
5: aload 0
getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
invokeinterface java.util.concurrent.ExecutorService.shutdownNow:()Ljava/util/List;
pop
6: goto 10
StackMap locals:
StackMap stack: java.lang.InterruptedException
7: astore 1
start local 1 8: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
9: getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
ldc "Interrupt on shutdown"
aload 1
invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 1 10: StackMap locals:
StackMap stack:
aload 0
invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
11: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
8 10 1 e Ljava/lang/InterruptedException;
Exception table:
from to target type
2 6 7 Class java.lang.InterruptedException
}
SourceFile: "DefaultProfileHandler.java"
InnerClasses:
public Summary = io.ebeaninternal.server.transaction.TransactionProfile$Summary of io.ebeaninternal.server.transaction.TransactionProfile
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles