私のプロジェクトの標準である log4j にリダイレクトされた BIRT のロギング (に基づいているようです) を取得することに関して、 BIRT FAQに従いました。java.util.logging
その後、次のように BIRT ロガーを作成しました。
public class BirtLogger extends Handler {
private final Logger log = Logger.getLogger(BirtLogger.class);
@Override
public void publish(LogRecord record) {
Level level = record.getLevel();
String message = record.getMessage();
if (Level.SEVERE.equals(level)) {
log.fatal(message);
}
else if (Level.INFO.equals(level)) {
log.info(message);
}
else if (Level.WARNING.equals(level)) {
log.warn(message);
}
}
...
そして、私の logging.properties は次のようになります。
#logging configuration for BIRT
handlers=com.totaalsoftware.fieldtracker.report.BirtLogger
この構成を 3 つの場所で使用しています。
- Eclipse --> 正常に動作します
- Tomcat --> 正常に動作します
org.apache.tomcat.maven:tomcat7-maven-plugin:2.0
--> 動作しない
後者では、起動時に次のエラー メッセージが表示されます。
java.lang.ClassNotFoundException: com.totaalsoftware.fieldtracker.report.BirtLogger
java.lang.ClassNotFoundException: com.totaalsoftware.fieldtracker.report.BirtLogger
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at java.util.logging.LogManager$3.run(LogManager.java:418)
at java.security.AccessController.doPrivileged(Native Method)
at java.util.logging.LogManager.loadLoggerHandlers(LogManager.java:405)
at java.util.logging.LogManager.initializeGlobalHandlers(LogManager.java:1076)
at java.util.logging.LogManager.access$1100(LogManager.java:148)
at java.util.logging.LogManager$RootLogger.getHandlers(LogManager.java:1159)
at java.util.logging.Logger.log(Logger.java:521)
at java.util.logging.Logger.doLog(Logger.java:543)
at java.util.logging.Logger.logp(Logger.java:659)
at org.apache.juli.logging.DirectJDKLog.log(DirectJDKLog.java:183)
at org.apache.juli.logging.DirectJDKLog.info(DirectJDKLog.java:126)
at org.apache.catalina.core.ApplicationContext.log(ApplicationContext.java:710)
at org.apache.catalina.core.ApplicationContextFacade.log(ApplicationContextFacade.java:298)
at org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:442)
at org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:133)
at javax.servlet.GenericServlet.init(GenericServlet.java:160)
at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1266)
at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1185)
at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1080)
at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:5027)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5314)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
at java.util.concurrent.FutureTask.run(FutureTask.java:166)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:722)
ただし、この「欠落している」クラスはアプリケーションのクラスパスにあると思います。しかし、Maven プラグインには、まだよく理解していないクラスローディングの特殊性があるかもしれtomcat7
ません...
私はこれについてかなりグーグルで調べましたが、まったく役に立たなかった「想定される」解決策がたくさん見つかりました。この時点ではアイデアがありません。どうぞよろしくお願いいたします。