2017-04-07 93 views
0

我已经搜索过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


非常感谢您提前!

回答

0

可耻的是我...我的问题是一个错字....

<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

+0

请标记为正确答案(即使是你的),以表明问题已解决。 – OndrejM

+0

对不起,我被删除了帖子,但是......还活着。 – Vielinko