public abstract class org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender<T extends org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager> extends org.apache.logging.log4j.core.appender.AbstractAppender
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender
super_class: org.apache.logging.log4j.core.appender.AbstractAppender
{
public static final int DEFAULT_RECONNECT_INTERVAL_MILLIS;
descriptor: I
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: 5000
private final java.util.concurrent.locks.ReadWriteLock lock;
descriptor: Ljava/util/concurrent/locks/ReadWriteLock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.Lock readLock;
descriptor: Ljava/util/concurrent/locks/Lock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.Lock writeLock;
descriptor: Ljava/util/concurrent/locks/Lock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private T manager;
descriptor: Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
flags: (0x0002) ACC_PRIVATE
Signature: TT;
protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, boolean, );
descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;ZLorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
aload 2
aconst_null
iload 3
getstatic org.apache.logging.log4j.core.config.Property.EMPTY_ARRAY:[Lorg/apache/logging/log4j/core/config/Property;
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
1: aload 0
new java.util.concurrent.locks.ReentrantReadWriteLock
dup
invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
2: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
3: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
4: aload 0
aload 4
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
5: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 6 1 name Ljava/lang/String;
0 6 2 filter Lorg/apache/logging/log4j/core/Filter;
0 6 3 ignoreExceptions Z
0 6 4 manager TT;
Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;ZTT;)V
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
name final
filter final
ignoreExceptions final
manager final
protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, boolean, org.apache.logging.log4j.core.config.Property[], );
descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=7, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
aload 1
aload 2
aload 3
iload 4
aload 5
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
1: aload 0
new java.util.concurrent.locks.ReentrantReadWriteLock
dup
invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
2: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
3: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
4: aload 0
aload 6
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
5: return
end local 6 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 6 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 6 1 name Ljava/lang/String;
0 6 2 filter Lorg/apache/logging/log4j/core/Filter;
0 6 3 layout Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
0 6 4 ignoreExceptions Z
0 6 5 properties [Lorg/apache/logging/log4j/core/config/Property;
0 6 6 manager TT;
Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;Z[Lorg/apache/logging/log4j/core/config/Property;TT;)V
MethodParameters:
Name Flags
name final
filter final
layout final
ignoreExceptions final
properties final
manager final
protected void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.Layout<? extends java.io.Serializable>, boolean, );
descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;ZLorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
aload 1
aload 2
aload 3
iload 4
getstatic org.apache.logging.log4j.core.config.Property.EMPTY_ARRAY:[Lorg/apache/logging/log4j/core/config/Property;
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
1: aload 0
new java.util.concurrent.locks.ReentrantReadWriteLock
dup
invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
2: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
3: aload 0
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.lock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
4: aload 0
aload 5
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
5: 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 6 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 6 1 name Ljava/lang/String;
0 6 2 filter Lorg/apache/logging/log4j/core/Filter;
0 6 3 layout Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;
0 6 4 ignoreExceptions Z
0 6 5 manager TT;
Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout<+Ljava/io/Serializable;>;ZTT;)V
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
name final
filter final
layout final
ignoreExceptions final
manager final
public final void append(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.lock:()V
1: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
aload 1
aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.toSerializable:(Lorg/apache/logging/log4j/core/LogEvent;)Ljava/io/Serializable;
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.write:(Lorg/apache/logging/log4j/core/LogEvent;Ljava/io/Serializable;)V
2: goto 16
StackMap locals:
StackMap stack: org.apache.logging.log4j.LoggingException
3: astore 2
start local 2 4: getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "Unable to write to database [{}] for appender [{}]."
aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.getName:()Ljava/lang/String;
5: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
aload 2
6: invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
7: aload 2
athrow
end local 2 8: StackMap locals:
StackMap stack: java.lang.Exception
astore 2
start local 2 9: getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "Unable to write to database [{}] for appender [{}]."
aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.getName:()Ljava/lang/String;
10: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
aload 2
11: invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
12: new org.apache.logging.log4j.core.appender.AppenderLoggingException
dup
new java.lang.StringBuilder
dup
ldc "Unable to write to database in appender: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 2
invokespecial org.apache.logging.log4j.core.appender.AppenderLoggingException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 2 13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 3
14: aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
15: aload 3
athrow
16: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.readLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
17: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 18 1 event Lorg/apache/logging/log4j/core/LogEvent;
4 8 2 e Lorg/apache/logging/log4j/LoggingException;
9 13 2 e Ljava/lang/Exception;
Exception table:
from to target type
1 2 3 Class org.apache.logging.log4j.LoggingException
1 2 8 Class java.lang.Exception
1 13 13 any
MethodParameters:
Name Flags
event final
public final org.apache.logging.log4j.core.Layout<org.apache.logging.log4j.core.LogEvent> getLayout();
descriptor: ()Lorg/apache/logging/log4j/core/Layout;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=1, locals=1, args_size=1
start local 0 0: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
Signature: ()Lorg/apache/logging/log4j/core/Layout<Lorg/apache/logging/log4j/core/LogEvent;>;
public final T getManager();
descriptor: ()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
Signature: ()TT;
protected final void replaceManager();
descriptor: (Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;)V
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.lock:()V
1: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
astore 2
start local 2 2: aload 1
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.isRunning:()Z
ifne 4
3: aload 1
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.startup:()V
4: StackMap locals: org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager
StackMap stack:
aload 0
aload 1
putfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.manager:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
5: aload 2
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.close:()V
end local 2 6: goto 10
StackMap locals: org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager
StackMap stack: java.lang.Throwable
7: astore 3
8: aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
9: aload 3
athrow
10: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.writeLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
11: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 12 1 manager TT;
2 6 2 old TT;
Exception table:
from to target type
1 7 7 any
Signature: (TT;)V
MethodParameters:
Name Flags
manager final
public final void start();
descriptor: ()V
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
ifnonnull 2
1: getstatic org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "No AbstractDatabaseManager set for the appender named [{}]."
aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getName:()Ljava/lang/String;
invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
2: StackMap locals:
StackMap stack:
aload 0
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.start:()V
3: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
ifnull 5
4: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.startup:()V
5: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
public boolean stop(long, java.util.concurrent.TimeUnit);
descriptor: (JLjava/util/concurrent/TimeUnit;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 3 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.setStopping:()V
1: aload 0
lload 1
aload 3
iconst_0
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.stop:(JLjava/util/concurrent/TimeUnit;Z)Z
istore 4
start local 4 2: aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
ifnull 4
3: iload 4
aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.getManager:()Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;
lload 1
aload 3
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseManager.stop:(JLjava/util/concurrent/TimeUnit;)Z
iand
istore 4
4: StackMap locals: int
StackMap stack:
aload 0
invokevirtual org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender.setStopped:()V
5: iload 4
ireturn
end local 4 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseAppender<TT;>;
0 6 1 timeout J
0 6 3 timeUnit Ljava/util/concurrent/TimeUnit;
2 6 4 stopped Z
MethodParameters:
Name Flags
timeout final
timeUnit final
}
Signature: <T:Lorg/apache/logging/log4j/core/appender/db/AbstractDatabaseManager;>Lorg/apache/logging/log4j/core/appender/AbstractAppender;
SourceFile: "AbstractDatabaseAppender.java"
NestMembers:
org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender$Builder
InnerClasses:
public Builder = org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender$Builder of org.apache.logging.log4j.core.appender.db.AbstractDatabaseAppender