有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

logback默认文件追加器的java位置

我有一个以logback作为日志功能的J2EE web应用程序 并使用Tomcat 7作为服务器。 我现在正在使用logback控制台Pender,所以我可以转到 /var/log/tomcat7/catalina。出去看看日志

现在,我想把日志移到一个文件中。我将使用RollingFileAppender保存日志

我不想使用绝对路径比如:

<appender name="FILE" class="xxx.RollingFileAppender">
    <file>/var/log/testFile1.log</file>
    <encoder>
      <pattern>%msg%n</pattern>
    </encoder>
</appender>

我也不想使用系统环境变量,比如:

<appender name="FILE" class="xxx.RollingFileAppender">
    <file>{LOG_LOCATION}\testFile2.log</file>
    <encoder>
      <pattern>%msg%n</pattern>
    </encoder>
</appender>

如果我只在标签中写日志文件的名称,比如:

<appender name="FILE" class="xxx.RollingFileAppender">
    <file>testFile3.log</file>
    <encoder>
      <pattern>%msg%n</pattern>
    </encoder>
</appender>

我将收到错误:

21:29:45,265 |-ERROR in ch.qos.logback.core.FileAppender[TEST_LOG] - openFile(testFile3.log,true) call failed. java.io.FileNotFoundException: testFile3.log (Permission denied)
        at java.io.FileNotFoundException: testFile3.log (Permission denied)
        at      at java.io.FileOutputStream.open(Native Method)
        at      at java.io.FileOutputStream.<init>(FileOutputStream.java:221)
        at      at ch.qos.logback.core.recovery.ResilientFileOutputStream.<init>(ResilientFileOutputStream.java:28)
        at      at ch.qos.logback.core.FileAppender.openFile(FileAppender.java:149)
        at      at ch.qos.logback.core.FileAppender.start(FileAppender.java:108)
        at      at ch.qos.logback.core.joran.action.AppenderAction.end(AppenderAction.java:96)
        at      at ch.qos.logback.core.joran.spi.Interpreter.callEndAction(Interpreter.java:317)
        at      at ch.qos.logback.core.joran.spi.Interpreter.endElement(Interpreter.java:196)
        at      at ch.qos.logback.core.joran.spi.Interpreter.endElement(Interpreter.java:182)
        at      at ch.qos.logback.core.joran.spi.EventPlayer.play(EventPlayer.java:62)
        at      at ch.qos.logback.core.joran.GenericConfigurator.doConfigure(GenericConfigurator.java:149)
        at      at ch.qos.logback.core.joran.GenericConfigurator.doConfigure(GenericConfigurator.java:135)
        at      at ch.qos.logback.core.joran.GenericConfigurator.doConfigure(GenericConfigurator.java:99)
        at      at ch.qos.logback.core.joran.GenericConfigurator.doConfigure(GenericConfigurator.java:49)
        at      at ch.qos.logback.classic.util.ContextInitializer.configureByResource(ContextInitializer.java:75)
        at      at ch.qos.logback.classic.util.ContextInitializer.autoConfig(ContextInitializer.java:148)
        at      at org.slf4j.impl.StaticLoggerBinder.init(StaticLoggerBinder.java:85)
        at      at org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:55)
        at      at org.slf4j.LoggerFactory.bind(LoggerFactory.java:128)
        at      at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:107)
        at      at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:295)
        at      at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:269)
        at      at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:156)
        at      at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:132)
        at      at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:657)
        at      at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:282)
        at      at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:106)
        at      at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4779)
        at      at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5273)
        at      at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
        at      at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:895)
        at      at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:871)
        at      at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:615)
        at      at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:958)
        at      at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1599)
        at      at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
        at      at java.util.concurrent.FutureTask.run(FutureTask.java:262)
        at      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at      at java.lang.Thread.run(Thread.java:744)

我可以创建一个只有其名称的日志文件吗? 如果是这样,Tomcat 7服务器中日志文件的默认位置在哪里


共 (1) 个答案

  1. # 1 楼答案

    您需要一个相对路径。指定<file>./testFile3.log</file> 通过运行一次,检查这是在哪里创建的

    请注意,这可能与用于启动应用程序的位置有关