log4j mysql_配置log4j属性文件以存储在mysql数据库中

小编典典

如果您使用的是mysql。创建一个文件log4j.properties。这对我有用。将其放在应用程序的根文件夹中。即所有软件包的根。我也有一个表日志,其中包含字段id,date,user,message和class。

log4j.rootLogger=DEBUG,DB

log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender

log4j.appender.DB.URL=jdbc:mysql://localhost:3306/test

log4j.appender.DB.user=root

log4j.appender.DB.password=root

log4j.appender.DB.sql=INSERT INTO logs(date, user, message,class) VALUES ('%d{yyyy-MM-dd HH:mm:ss}', '%X{User}','%m','%c')

log4j.appender.DB.layout=org.apache.log4j.PatternLayout

log4j.appender.CA.layout.ConversionPattern=INSERT INTO logs (date, user,message,class) VALUES ('%d{yyyy-MM-dd HH:mm:ss}', '%X{User}','%m','%c')

log4j.category.ke.co=ERROR

log4j.category.ke.co.appender-ref=DB

然后按如下方式使用它。

package com.zeddarn;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

import org.apache.log4j.Logger;

import org.apache.log4j.MDC;

public class MySQLDatabaseConnector {

static ThreadLocal connection = new ThreadLocal();

private static Logger logger = Logger.getLogger(MySQLDatabaseConnector.class);

public static Connection getDBConnection() {

//check if a mysql connection already exits. This is to avoid reconnecting

if (connection.get() == null) {

try {

//loading the mysql driver. This means you also have to add mysql libary. You can add manually or via maven

Class.forName("com.mysql.jdbc.Driver");

} catch (ClassNotFoundException e) {

//do something to deal with the error of missing mysql driver e.g notification to the user.

MDC.put("User", "loggeduser");

logger.error(e.getMessage());

MDC.getContext().clear();

}

try {

connection.set(DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root"));

} catch (SQLException e) {

MDC.put("User", "loggeduser");

logger.error(e.getMessage());

MDC.getContext().clear();

}

}

return connection.get();

}

public static void main(String args[]) {

MDC.put("User", "loggeduser");

logger.error("message from exception.getMessage() method");

MDC.getContext().clear();

}

}

2020-11-01

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值