springMvc+MyBatis+Maven配置和log4j相似的Logback
實際上本文是配置與log4j相似的Logback!
pom.xml載入日誌相關包:
web.xml配置載入log4j:
根據需求logback.xml相關log4j配置:
詳細可參考:
日誌元件logback的介紹及配置使用方法:http://blog.csdn.net/zgmzyr/article/details/8267072
logback系列之三:輸出日誌到檔案(滾動):http://czj4451.iteye.com/blog/1975937
pom.xml載入日誌相關包:
<!-- log begin -->
<dependency>
<groupId>com.googlecode.log4jdbc</groupId>
<artifactId>log4jdbc</artifactId>
<version>1.2</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency>
<!-- 程式碼直接呼叫log4j會被橋接到slf4j -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency>
<!-- 程式碼直接呼叫common-logging會被橋接到slf4j -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency>
<!-- 程式碼直接呼叫java.util.logging會被橋接到slf4j -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jul-to-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency>
<!-- log end -->
web.xml配置載入log4j:
<!-- login4j begin -->
<!-- 設定log4j存放Log檔案位置(通過spring統一進行管理) -->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>log.root</param-value>
</context-param>
<!-- 載入log4j的配置檔案 -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>classpath:/logback.xml</param-value>
</context-param>
<!--Spring預設重新整理Log4j配置檔案的間隔,單位為millisecond-->
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param>
<!--Spring用於log4j初始化的監聽器-->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<!-- login4j end -->
根據需求logback.xml相關log4j配置:
<?xml version="1.0" encoding="UTF-8"?>
<configuration info="true">
<!-- 應用名稱 -->
<property name="APP_NAME" value="wanxue" />
<!--日誌檔案的儲存路徑,首先查詢系統屬性-Dlog.dir,如果存在就使用其;否則,在當前目錄下建立名為logs目錄做日誌存放的目錄 -->
<property name="LOG_HOME" value="D:\\wanxueLog4j" />
<!-- 日誌輸出格式 -->
<property name="ENCODER_PATTERN"
value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level 類名:%logger{80} 方法名:%M 行號:%L- %msg%n" />
<contextName>${APP_NAME}</contextName>
<!-- 控制檯日誌:輸出全部日誌到控制檯 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>${ENCODER_PATTERN}</Pattern>
</encoder>
</appender>
<!-- 檔案日誌:輸出全部日誌到檔案 -->
<appender name="FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/output.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 儲存30天日誌檔案 -->
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${ENCODER_PATTERN}</pattern>
</encoder>
</appender>
<!-- 錯誤日誌:用於將錯誤日誌輸出到獨立檔案 -->
<appender name="ERROR_FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/error.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${ENCODER_PATTERN}</pattern>
</encoder>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>WARN</level>
</filter>
</appender>
<!-- 獨立輸出的同步日誌 -->
<appender name="SYNC_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/sync.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${ENCODER_PATTERN}</pattern>
</encoder>
</appender>
<logger name="log.sync" level="INFO" addtivity="true">
<appender-ref ref="SYNC_FILE" />
</logger>
<!-- 全域性輸出的方式 -->
<root level="INFO">
<appender-ref ref="STDOUT" />
<appender-ref ref="FILE" />
<appender-ref ref="ERROR_FILE" />
</root>
</configuration>
詳細可參考:
日誌元件logback的介紹及配置使用方法:http://blog.csdn.net/zgmzyr/article/details/8267072
logback系列之三:輸出日誌到檔案(滾動):http://czj4451.iteye.com/blog/1975937
相關文章
- Logback配置
- logback的簡單配置
- Logback簡介及配置檔案logback.xml詳解XML
- SpringBoot之logback配置檔案Spring Boot
- Spring Boot logback日誌配置Spring Boot
- logback的使用和logback.xml詳解XML
- Spring配置log4jSpring
- 從log4j切換到logback後專案無法啟動
- springboot logback配置mybatis 日誌以及多環境配置Spring BootMyBatis
- 【Java】【SpringBoot】logback開發環境配置JavaSpring Boot開發環境
- 掃描重複和類似的 CSSCSS
- logback + slf4j idea配置使用技巧Idea
- springboot專案配置logback日誌系統Spring Boot
- commons-logging,log4j,logback,slf4j之間的關係詳解
- log4j簡單配置解釋
- Git命令的使用和相關配置Git
- springboot使用logback記錄日誌,配置檔案Spring Boot
- spring cloud腳手架專案(十一)logback配置SpringCloud
- logback1.3.x配置詳解與實踐
- J2SE - 關於Commons-Logging、Slf4j、Log4j、Logback的整理
- log4j日誌級別以及配置
- 配置LOG4J(log4j-1.2.17)
- Logback詳細整理,基於springboot的日誌配置Spring Boot
- logback 配置將IDEA 的 console log 存入到檔案Idea
- logback配置不當導致頻繁類載入
- 一文讀懂常用日誌框架(Log4j、SLF4J、Logback)有啥區別框架
- log4j 動態配置,重啟專案配置失效問題
- springboot超級詳細的日誌配置(基於logback)Spring Boot
- 為什麼阿里巴巴禁止工程師直接使用日誌系統(Log4j、Logback)中的API阿里工程師API
- 為什麼阿里巴巴禁止工程師直接使用日誌系統(Log4j、Logback)中的 API阿里工程師API
- 帶你深入Java Log框架,徹底搞懂Log4J、Log4J2、LogBack,SLF4JJava框架
- VScode配置xdebug相關配置VSCode
- Spring配置相關Spring
- Git 相關配置Git
- JDBC 相關配置JDBC
- nginx配置相關Nginx
- springboot 整合LogBackSpring Boot
- Logback配置檔案這麼寫,還愁不會整理日誌?
- IDEA 配置環境和相關工具整理(新手入門)Idea