1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.logging.log4j.core.appender.db;
18
19 import java.util.concurrent.locks.Lock;
20 import java.util.concurrent.locks.ReadWriteLock;
21 import java.util.concurrent.locks.ReentrantReadWriteLock;
22
23 import org.apache.logging.log4j.LoggingException;
24 import org.apache.logging.log4j.core.Filter;
25 import org.apache.logging.log4j.core.Layout;
26 import org.apache.logging.log4j.core.LogEvent;
27 import org.apache.logging.log4j.core.appender.AbstractAppender;
28 import org.apache.logging.log4j.core.appender.AppenderLoggingException;
29
30
31
32
33
34
35
36
37
38 public abstract class AbstractDatabaseAppender<T extends AbstractDatabaseManager> extends AbstractAppender {
39
40 private final ReadWriteLock lock = new ReentrantReadWriteLock();
41 private final Lock readLock = lock.readLock();
42 private final Lock writeLock = lock.writeLock();
43
44 private T manager;
45
46
47
48
49
50
51
52
53
54
55 protected AbstractDatabaseAppender(final String name, final Filter filter, final boolean ignoreExceptions,
56 final T manager) {
57 super(name, filter, null, ignoreExceptions);
58 this.manager = manager;
59 }
60
61
62
63
64
65
66
67 @Override
68 public final Layout<LogEvent> getLayout() {
69 return null;
70 }
71
72
73
74
75
76
77 public final T getManager() {
78 return this.manager;
79 }
80
81 @Override
82 public final void start() {
83 if (this.getManager() == null) {
84 LOGGER.error("No AbstractDatabaseManager set for the appender named [{}].", this.getName());
85 }
86 super.start();
87 if (this.getManager() != null) {
88 this.getManager().startup();
89 }
90 }
91
92 @Override
93 public final void stop() {
94 super.stop();
95 if (this.getManager() != null) {
96 this.getManager().release();
97 }
98 }
99
100 @Override
101 public final void append(final LogEvent event) {
102 this.readLock.lock();
103 try {
104 this.getManager().write(event);
105 } catch (final LoggingException e) {
106 LOGGER.error("Unable to write to database [{}] for appender [{}].", this.getManager().getName(),
107 this.getName(), e);
108 throw e;
109 } catch (final Exception e) {
110 LOGGER.error("Unable to write to database [{}] for appender [{}].", this.getManager().getName(),
111 this.getName(), e);
112 throw new AppenderLoggingException("Unable to write to database in appender: " + e.getMessage(), e);
113 } finally {
114 this.readLock.unlock();
115 }
116 }
117
118
119
120
121
122
123
124
125 protected final void replaceManager(final T manager) {
126 this.writeLock.lock();
127 try {
128 final T old = this.getManager();
129 if (!manager.isRunning()) {
130 manager.startup();
131 }
132 this.manager = manager;
133 old.release();
134 } finally {
135 this.writeLock.unlock();
136 }
137 }
138 }