sne*_*hal 10 java tomcat logback playframework-2.0
我为我的应用程序编写了logback配置文件,但是当我在进行maven clean install(mvn clean install)时,它在项目目录中生成了一个带有日志文件的catalina.home_IS_UNDEFINED目录.为什么生成这个目录?
我不希望它出现在我的项目目录中.
有任何帮助来解决这个问题吗?
这是配置文件.
<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%date{HH:mm:ss.SSS} %-5p [%t] %c{1} - %m%n</pattern>
</encoder>
</appender>
<appender name="MY_APP_LOG" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${catalina.home}/logs/myApplication.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>${catalina.home}/logs/myApplication.%d{yyyy-MM-dd}.log</FileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%-5p %date{HH:mm:ss.SSS} [%t] %c{1} - %m%n</pattern>
</encoder>
<append>true</append>
</appender>
<logger name="org.springframework" level="WARN"/>
<root>
<priority value="INFO"/>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="MY_APP_LOG"/>
</root>
</configuration>
Run Code Online (Sandbox Code Playgroud)
Glo*_*ber 11
此属性加载失败,因为它仅由tomcat填充.它不是由maven编译任务填充的.
在logback.xml中设置这样的属性
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<if condition='isDefined("catalina.home")'>
<then>
<property name="log.folder" value="${catalina.home}/logs"/>
</then>
<else>
<property name="log.folder" value="./target/logs"/>
</else>
</if>
<appender name="companyMyAppServiceAppender" class="ch.qos.logback.core.FileAppender">
<file>${log.folder}/company.myApp.log</file>
...
</appender>
...
</configuration>
Run Code Online (Sandbox Code Playgroud)
这将在编译时在目标文件夹中创建日志文件,该文件将被清除.
"重写"值:
<property name="log.folder" value="./target/logs"/>
<if condition='isDefined("catalina.home")'>
<then>
<property name="log.folder" value="${catalina.home}/logs"/>
</then>
</if>
Run Code Online (Sandbox Code Playgroud)
并且不要忘记导入maven janino依赖
<!-- The org.codehaus.janino:commons-compiler:2.7.8 dependency -->
<!-- will be automatically pulled in by Maven's transitivity rules -->
<dependency>
<groupId>org.codehaus.janino</groupId>
<artifactId>janino</artifactId>
<version>2.7.8</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)
我建议不要依赖 janino 依赖项(在本例中 1 MB 毫无用处),有一个更简单的解决方案,使用 logback 的默认值实现,如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<property name="base.folder" value="${catalina.home:-./target}"/>
<appender name="MY_APP_LOG" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${base.folder}/logs/myApplication.log</file>
...
</appender>
...
</configuration>
Run Code Online (Sandbox Code Playgroud)
查找:-变量名称和默认值之间的字符。如果变量为空,则将使用${catalina.home}默认值(在本例中)。./target
IPr*_*ory -4
尝试改变:
<logger name="org.springframework" level="WARN"/>
Run Code Online (Sandbox Code Playgroud)
到:
<logger name="org.springframework" level="OFF"/>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5231 次 |
| 最近记录: |