log4j 日誌除了在本地控制檯打印輸出外,還可以寫入數據庫中(這裏以MySQL數據庫爲例)
1.簡單的maven項目構建
1.1 log4j.properties
log4j.rootLogger=INFO,database,stdout
### 把日誌信息輸出到控制檯 ###
#日誌信息將寫到控制檯
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#信息打印到System.out上
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
#指定輸出格式:顯示日期和log信息
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %m%n
### 把日誌信息寫入到數據庫###
log4j.appender.database=org.apache.log4j.ConsoleAppender
log4j.appender.database.layout=org.apache.log4j.PatternLayout
log4j.appender.database.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss:SSS}[%p]: %m%n
log4j.appender.database=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.database.driver=com.mysql.jdbc.Driver
log4j.appender.database.URL=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8
log4j.appender.database.user=root
log4j.appender.database.password=admin
log4j.appender.database.sql=insert into log (class,method,createtime,loglevel,msg) VALUES ('%C','%M','%d{yyyy-MM-dd hh:mm:ss}','%p','%m')
log4j.appender.database.layout=org.apache.log4j.PatternLayout
1.2 maven的pom.xml文件
這裏需要注意下,MySQL的版本不能太高,否則會報錯。
<dependencies>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.0.5</version>
</dependency>
</dependencies>
1.3 web.xml可以什麼都沒有,只需要一個空文件即可。
1.4 數據庫表(表名log,表字段見名知意)
1.5 測試類
import org.apache.log4j.Logger;
public class Test {
private static Logger logger = Logger.getLogger(Test.class);
public static void main(String[] args) {
logger.info("測試信息5");
}
}
好了,這就是一個簡單的demo,大家可以看看。