Logback RollingFileAdapter在Payara服务器中无法正常工作
问题描述:
我已经搜索过stackoverflow和谷歌它很多,但我的问题还没有解决。Logback RollingFileAdapter在Payara服务器中无法正常工作
问题:
在代码我有这些记录程序:
@Stateless
public class NotificatrionService implements INotificationService {
private final static Logger logger = LoggerFactory.getLogger("DEF");
private final static Logger logger_wsdlr = LoggerFactory.getLogger("wsdlr");
:
:
}
并且在某些情况下,我使用的每个一个
:
logger_wsdlr.info("Some info messages");
:
logger.debug("Some debug messages"));
:
要设置的logback与Payara Server 4
(稳定Glassfish的4),按照@vzamanillo写在这篇文章中的说明:
cannot get SLF4J working with glassfish 4
在该指南(或其他找到的人)使用ch.qos.logback.core.FileAppender
。有了这个appender logback工作得很好,但我需要旋转日志文件。然后,我只是设置ch.qos.logback.core.rolling.RollingFileAppender
在我logback.xml
,就像这样:
<configuration scan="true" debug="true">
<contextListener class="ch.qos.logback.classic.jul.LevelChangePropagator">
<resetJUL>true</resetJUL>
</contextListener>
<property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level][%thread][%logger{36}]%msg%n"/>
<property name="dir" value="/tmp/log"/>
<appender name="DEF" class="ch.qos.logback.core.FileAppender">
<file>${com.sun.aas.instanceRoot}/logs/my_def.log</file>
<append>true</append>
<encoder>
<Pattern>${pattern}</Pattern>
</encoder>
</appender>
<appender name="WSDLR" class="ch.qos.logback.core.RollingFileAppender">
<file>${dir}/dt_wsdlr.log</file>
<append>true</append>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${dir}/dt_wsdlr-%d{yyyy.MM.dd}.log</fileNamePattern>
<maxHistory>90</maxHistory>
<totalSizeCap>3GB</totalSizeCap>
</rollingPolicy>
<encoder>
<Pattern>${pattern}</Pattern>
</encoder>
</appender>
<!-- appender that replace payara default server.log, defualt was redirected to ${com.sun.aas.instanceRoot}/tmp/server.log -->
<appender name="GF" class="ch.qos.logback.core.FileAppender">
<file>${com.sun.aas.instanceRoot}/logs/server.log</file>
<append>true</append>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level>
</filter>
<encoder>
<Pattern>${pattern}</Pattern>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="GF"/>
</root>
<logger level="TRACE" name="DEF" additivity="false">
<appender-ref ref="STDOUT"/>
</logger>
<logger level="DEBUG" name="wsdlr" additivity="false">
<appender-ref ref="WSDLR"/>
</logger>
</configuration>
当我用我的代码RollingFileAppender
参考,根本就没有被创建相关的附加器文件和日志只是缺少。
我尝试从上面提到的职位(@casten post),而只是一个新的错误申请步骤募
2017-04-07 10:49:25.297 [ERROR][Thread-20][j.e.system.tools.deployment.common]Exception while invoking class com.sun.enterprise.web.WebApplication start method
java.lang.Exception: java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: java.lang.NoClassDefFoundError: javax/servlet/ServletContainerInitializer
at com.sun.enterprise.web.WebApplication.start(WebApplication.java:168)
at org.glassfish.internal.data.EngineRef.start(EngineRef.java:122)
at org.glassfish.internal.data.ModuleInfo.start(ModuleInfo.java:291)
at org.glassfish.internal.data.ApplicationInfo.start(ApplicationInfo.java:353)
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:501)
at com.sun.enterprise.v3.server.ApplicationLoaderService.processApplication(ApplicationLoaderService.java:406)
at com.sun.enterprise.v3.admin.adapter.InstallerThread.load(InstallerThread.java:211)
at com.sun.enterprise.v3.admin.adapter.InstallerThread.run(InstallerThread.java:100)
2017-04-07 10:49:25.297 [ERROR][Thread-20][javax.enterprise.system.core]Exception during lifecycle processing
java.lang.Exception: java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: java.lang.NoClassDefFoundError: javax/servlet/ServletContainerInitializer
at com.sun.enterprise.web.WebApplication.start(WebApplication.java:168)
at org.glassfish.internal.data.EngineRef.start(EngineRef.java:122)
at org.glassfish.internal.data.ModuleInfo.start(ModuleInfo.java:291)
at org.glassfish.internal.data.ApplicationInfo.start(ApplicationInfo.java:353)
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:501)
at com.sun.enterprise.v3.server.ApplicationLoaderService.processApplication(ApplicationLoaderService.java:406)
at com.sun.enterprise.v3.admin.adapter.InstallerThread.load(InstallerThread.java:211)
at com.sun.enterprise.v3.admin.adapter.InstallerThread.run(InstallerThread.java:100)
我刚回退瓶的位置。
任何人都可以帮助我找到正确的方式使用RollingFileAppender
?
非常感谢您提前!
答
可耻的是我...我的问题是一个错字....
<appender name="WSDLR" class="ch.qos.logback.core.RollingFileAppender">
<file>${dir}/dt_wsdlr.log</file>
<append>true</append>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${dir}/dt_wsdlr-%d{yyyy.MM.dd}.log</fileNamePattern>
<maxHistory>90</maxHistory>
<totalSizeCap>3GB</totalSizeCap>
</rollingPolicy>
<encoder>
<Pattern>${pattern}</Pattern>
</encoder>
</appender>
正确的类引用是ch.qos.logback.core.rolling.RollingFileAppender
而不是ch.qos.logback.core.RollingFileAppender
。
请标记为正确答案(即使是你的),以表明问题已解决。 – OndrejM
对不起,我被删除了帖子,但是......还活着。 – Vielinko