使用log4j将日志信息写入数据库中

一直都在想如何用log4j将message写到数据库中,在以后查看的时候会方便些。(数据库都是使用MSSQL)

在网上搜了下, 有两种方法比较合适。

1.插入数据库中的表的字段有多个(不包括自动增长列),这种情况适合在浏览时要对某个字段进行排序等其他需求。
配置文件主要部分如下:

< appender  name ="access_Log_JDBC"  class ="org.apache.log4j.jdbc.JDBCAppender" >
< param  name ="Driver"  value ="com.microsoft.jdbc.sqlserver.SQLServerDriver"   />
< param  name ="URL"  value ="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=LOG"   />
< param  name ="user"  value ="sa"   />
< param  name ="password"  value ="sa"   />
< param  name ="sql"  value ="INSERT INTO t(date,user,b,message) VALUES (getDate(), '%X{user}', '%X{b}', '%m')"   />
< param  name ="BufferSize"  value ="1"   />
</ appender >  

< category  name ="accesslog_category" >
< priority  value ="debug"   />
< appender-ref  ref ="access_Log_JDBC"   />
< appender-ref  ref ="CONSOLE"   />
</ category >


java 部分代码如下:

//MDC的帮助页面:http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/MDC.html

public   class  AccessLogFactory  {
private static final String ACCESSLOG_CATEGORY = "accesslog_category";

static{
DOMConfigurator.configure(
"./conf/log4j.xml");
}


public static Log getLog() {

Log logger 
= null;

try {
logger 
= LogFactory.getLog(ACCESSLOG_CATEGORY);
}
 catch (LogConfigurationException e) {
e.printStackTrace();
}


return logger;
}


public static void main(String[] args){
Log logger 
= AccessLogFactory .getLog();
String msg 
= "b03";
String user 
= "u03";
String b 
= "b03";
MDC.put(
"user", user); //和配置文件中的%X{user}对应
MDC.put("b", b); //和配置文件中的%X{b}对应
logger.error(msg); //和配置文件中的%m对应


msg 
= "b04";
user 
= "u04";
= "b04";
MDC.put(
"user ", user );
MDC.put(
"b", b);
logger.error(msg);
}

}




2.插入数据库中的表的字段有一个(不包括自动增长列),这种情况适合只是要显示在页面上而无其他需求,当然第一种情况也适合(这部分的代码来自http://hi.baidu.com/kekemao1/blog/item/199d3d31ed6d901aebc4afff.html)。

放在WEB_INF/class文件夹下的log.properties文件的内容如下

# log4j . rootLogger = DEBUG ,  DATABASE 
# log4j . appender . DATABASE = org . apache . log4j . jdbc . JDBCAppender // (root日志记录器的存储器)
# log4j . appender . DATABASE . URL = jdbc :microsoft:sqlserver : // localhost: 1433 ; SelectMethod = cursor
# log4j . appender . DATABASE . driver = com . microsoft . jdbc . sqlserver . SQLServerDriver
# log4j . appender . DATABASE . user = sd  // 用户名
# log4j . appender . DATABASE . password =
# log4j . appender . DATABASE . sql = INSERT INTO LOG4J  ( Message )  VALUES  ( '%d %c %p %m%n' )// 写入pubs数据库中的表LOG4J的Message字段中,内容%d(日期)%c: 日志信息所在地(类名)%p: 日志信息级别%m: 产生的日志具体信息 %n: 输出日志信息换行 
# log4j . appender . DATABASE . layout = org . apache . log4j . PatternLayout
# log4j . appender . DATABASE . layout . ConversionPattern = %d %c %p %m%n



java 代码:

import  org.apache.log4j.Logger;
import  org.apache.log4j.MDC;
import  javax.sql.DataSource;
import  javax.naming.Context;
import  javax.naming.InitialContext;
import  java.sql.Connection;
import  java.sql.SQLException;
import  java.util.Vector;

/**
* 封装DataSource
*
@version 1.0, 2005-9-16 11:18:44
*/


public   class  DataSourcePackBean  {
     
/**
      * log4j
      
*/

     
private Logger logger = Logger.getLogger(DataSourcePackBean.class);

//DataSourcePackBean.class日志记录器的名与类名相同;

     
/**
      * 引用名
      
*/

     
private String ref;

     
/**
      * DataSource对象
      
*/

     
private DataSource ds;

     
/**
      * 保存当前DataSource对象中所有打开的Connection对象的引用。
      
*/

     
private Vector openedConnections = new Vector();

     
/**
      * 接收DataSource引用名,查找DataSource对象。
      *
      * 
@param ref DataSource引用名
      
*/

     
protected DataSourcePackBean(String ref) {
         
this.ref = ref;
         
this.ds = lookup(ref);
     }


     
public String getRef() {
         
return ref;
     }


     
public int getActive() {
         
return openedConnections.size();
     }


     
/**
      * 打开一个连接
      *
      * 
@param username 连接数据库的登录用户名,如果为null,表示用默认用户连接
      * 
@param password 连接数据库的登录密码
      * 
@return
      * 
@throws SQLException
      
*/

     
public Connection getConnection(String username, String password) throws SQLException {
         Connection conn 
= (username == null? ds.getConnection() : ds.getConnection(username, password);
         
// add to vector
         openedConnections.add(conn);
         
// log
         StringBuffer log = new StringBuffer();
         log.append(
"Open").append(" a connection(").append(conn.hashCode()).append(") of [").append(ref).append("] ");
         log.append(openedConnections.size()).append(
" connection").append(" in use");
         logger.debug(log);
         
// return
         return conn;
     }


     
/**
      * 关闭一个连接
      *
      * 
@param conn
      * 
@throws SQLException
      
*/

     
public void closeConnection(Connection conn) throws SQLException {
         conn.close();
         
// remove from Vector
         openedConnections.remove(conn);
         
// log
         StringBuffer log = new StringBuffer();
         log.append(
"Close").append(" a connection(").append(conn.hashCode()).append(") of [").append(ref).append("] ");//添加内容到日志记录中
         log.append(openedConnections.size()).append(" connection").append(" in use");
         logger.debug(log);
     }


     
/**
      * close all Connection of this DataSource
      * 
@throws SQLException
      
*/

     
public void closeAll() throws SQLException {
         
for (int i = 0; i < openedConnections.size(); i++{
             ((Connection)openedConnections.get(i)).close();
         }

         
// clear Vector
         openedConnections.removeAllElements();
     }


     
/**
      * get a DataSource
      * 
@param ref the JNDI name of the DataSource
      * 
@return
      
*/

     
private DataSource lookup(String ref) {
         DataSource dataSource 
= null;
         
// 查找ref数据源对象
         try {
             Context env 
= new InitialContext();
             dataSource 
= (DataSource) env.lookup(ref);
             
// 测试数据库有效性
             dataSource.getConnection().close();
             logger.debug(
new StringBuffer().append("DataSource[").append(ref).append("] has been initialized successfully."));
         }
 catch (Exception e) {
             e.printStackTrace();
         }

         
// return
         return dataSource;
     }


     
public SQLRunnerIfc getSQLRunner(String username, String password) throws SQLException {
         
return new SQLRunner(username, password, this);
     }


     
public SQLRunnerIfc getSQLRunner() throws SQLException {
         
return getSQLRunner(nullnull);
     }

}


  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以的,以下是Java代码实现log4j2日志写入MySQL数据库的示例: 1. 首先,需要在pom.xml文件添加以下依赖: ``` <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.14.1</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.14.1</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-slf4j-impl</artifactId> <version>2.14.1</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> ``` 2. 在log4j2.xml文件配置MySQL数据库的Appender: ``` <?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <JDBC name="databaseAppender" tableName="logs"> <ConnectionFactory class="com.mysql.cj.jdbc.MysqlDataSource"> <param name="url" value="jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC"/> <param name="user" value="root"/> <param name="password" value="123456"/> </ConnectionFactory> <Column name="timestamp" isEventTimestamp="true"/> <Column name="level" pattern="%level"/> <Column name="logger" pattern="%logger"/> <Column name="message" pattern="%message"/> </JDBC> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="databaseAppender"/> </Root> </Loggers> </Configuration> ``` 3. 在Java代码使用log4j2记录日志: ``` import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; public class Main { private static final Logger logger = LogManager.getLogger(Main.class); public static void main(String[] args) { logger.info("Hello, log4j2!"); } } ``` 4. 最后,在MySQL数据库创建表logs: ``` CREATE TABLE logs ( id INT NOT NULL AUTO_INCREMENT, timestamp TIMESTAMP NOT NULL, level VARCHAR(10) NOT NULL, logger VARCHAR(100) NOT NULL, message TEXT NOT NULL, PRIMARY KEY (id) ); ``` 这样,log4j2就会将日志记录到MySQL数据库的logs表

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值