log4j学习日记-写入数据库
1、首先创建日志数据库
用的是MySQL
CREATE TABLE `td_log` (
`lid` int(11) NOT NULL AUTO_INCREMENT,
`lusername` varchar(20) DEFAULT NULL,
`lmessage` varchar(200) DEFAULT NULL,
`lstartdate` varchar(30) DEFAULT NULL,
`level` varchar(20) DEFAULT NULL,
PRIMARY KEY (`lid`)
)
2、配置文件中的部分内容:
log4j.rootLogger=info,jdbc
#直接使用log4j包中的文件
log4j.appender.jdbc=org.apache.log4j.jdbc.JDBCAppender
#与数据库建立连接
log4j.appender.jdbc.URL=jdbc:mysql://localhost:3306/test
log4j.appender.jdbc.driver=com.mysql.jdbc.Driver
log4j.appender.jdbc.user=root
log4j.appender.jdbc.password=admin
log4j.appender.jdbc.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %5p %t %c{2}:%L - %m%n
#指定要插入数据库的格式,与数据库字段对应,与一般SQL区别不大,只是加上了log4j的一些配置参数而已。
log4j.appender.jdbc.sql=insert into td_log(lusername, lstartdate, level, lmessage) values ('%X{lusername}','%d{yyyy-MM-dd HH:mm:ss}','%p','%m')
3、日志工具类源码如下
/**
* 系统日志辅助类
* @author
* @date */
public class LogUtil{
/**
* 崩溃级别
* @param lusername
* @param message
*/
public static void fatal(Logger logger, String lusername,String message){
MDC.put("lusername", lusername);
logger.fatal(message);
}
/**
* 错误级别
* @param username
* @param message
*/
public static void error(Logger logger, String lusername,String message){
MDC.put("lusername", lusername);
logger.error(message);
}
/**
* 错误级别
* @param username
* @param message
*/
public static void error(Logger logger, String lusername, Object message){
MDC.put("lusername", lusername);
logger.error(message);
}
/**
* 消息级别
* @param logger
* @param username
* @param message
*/
public static void info(Logger logger, String lusername,String message){
MDC.put("lusername", lusername);
logger.info(message);
}
/**
* 警告级别
* @param username
* @param message
*/
public static void warn(Logger logger, String lusername,String message){
MDC.put("lusername", lusername);
logger.warn(message);
}
/**
* 调试级别
* @param username
* @param message
*/
public static void debug(Logger logger, String lusername,String message){
MDC.put("lusername", lusername);
logger.debug(message);
}
}
4、客户端调用源码
public class test{
private static Logger logger = Logger.getLogger(test.class);
public static void main(String[] args) {
LogUtil.info(logger, "wyw", "看看是否写入了数据库");
}
}
log4j学习日记-写入数据库的更多相关文章
- 怎样借助log4j把日志写入数据库中
log4j是一个优秀的开源日志记录项目.我们不仅能够对输出的日志的格式自定义,还能够自定义日志输出的目的地,比方:屏幕.文本文件,数据 库,甚至能通过socket输出.本节使用MySQ ...
- 使用log4j将日志写入数据库并发送邮件
参考: 快速了解Log4J 1.log4j的初始配置 参考该问的配置即可完整的实现写入数据库及发送邮件的功能 a.写入数据库需要配置相应的jar包,数据库类型不同,请使用指定的数据库配置,该文仅限于o ...
- 用log4j将日志写入数据库
以下为log4j中的配置参数: %m 输出代码中指定的消息 %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL %r 输出自应用启动到输出该log信息耗费的毫秒数 %t 输出产 ...
- 使用log4j让日志写入数据库
之前做的一个项目有这么个要求,在日志管理系统里,需要将某些日志信息存储到数据库里,供用户.管理员查看分析.因此我就花了点时间搞了一下这一功能,各位请看. 摘要:我们知道log4j能提供强大的可配置的记 ...
- Log4j写入数据库详解
log4j是一个优秀的开源日志记录项目,我们不仅可以对输出的日志的格式自定义,还可以自己定义日志输出的目的地,比如:屏幕,文本文件,数据库,甚至能通过socket输出.本节主要讲述如何将日志信息输入到 ...
- (OAF)jdeveloper集成log4j并将日志输出到指定文件并写入数据库
参考: How to configure Log4j in JDev 11g Ever wanted to use log4j in your adf project ? Well though Or ...
- Log4j(一):Log4j将日志信息写入数据库
前言 为了监听一些数据的采集等功能,需要随时监听设备的状态,所以需要运行的时候将日志打入到数据库中. 正文 第一步: 首先是jar包,由于我使用的是springboot,所以,在springboot- ...
- flume学习(三):flume将log4j日志数据写入到hdfs(转)
原文链接:flume学习(三):flume将log4j日志数据写入到hdfs 在第一篇文章中我们是将log4j的日志输出到了agent的日志文件当中.配置文件如下: tier1.sources=sou ...
- log4j日志写入数据库
# log4j写入数据库 ### 前言-----------------------------log4j是写入日志到控制台和文件很常见,但是写入到数据库不多见.做性能测试写入到数据库,统计方便些. ...
随机推荐
- Android(java)学习笔记175:BroadcastReceiver之 外拨电话的广播接收者
首先我们示例工程一览表如下: 1.首先我们还是买一个收音机,定义一个OutCallReceiver继承自BroadcastReceiver,onReceive()方法中定义了监听到广播,要执行的操作: ...
- Android(java)学习笔记193:利用谷歌API对数据库增删改查(推荐使用)
接下来我们通过项目案例来介绍:这个利用谷歌API对数据库增删改查 1.首先项目图: 2.这里的布局文件activity_main.xml: <LinearLayout xmlns:android ...
- 初建FreeMarker工程
初建FreeMarker工程 ——@梁WP 背景:听说freemarker可以用来写页面的组件,热衷于编写可重用代码的我,迫不及待地研究了freemarker,不过,在写组件之前,还是先研究一下fre ...
- [转载]Oracle基础知识
一.oracle安装过程略 二.sys用户和system用户 (1)sys用户是超级用户,具有最高权限,具有sysdba角色,有create database的权限 默认密码是change_onins ...
- VS2008 未找到编译器可执行文件 csc.exe【当网上其他方法试玩了之后不起作用的时候再用这个方法】
被公司派遣到中国海洋石油惠州炼化公司做项目,做的是生产管理,来了发现他们的项目结构简直烂的要命,和同学们写的毕业设计差不多,然后开发工具用的是vs2008,我电脑是安装了vs2005和vs2010,v ...
- windows 远程连接linux服务器
百度搜索“SSH Secure Shell Client” 并下载 2 点击Profiles选择add profiles 并添加profils名称 3 点击Profiles 填写远程linux的ip ...
- linux命令sed学习笔记
sed其实就是两个主要的知识点,那就是“怎么选择”和“怎么操作”!
- ie8中parseInt字符型数值转换数值型问题
今天在ie8中测试项目发现一个奇怪的问题,"08" "09" 强转竟然变成了: 后来发现ie8把"08" "09" 默认 ...
- 两个winform窗体同步
/// <summary> /// 初始left距离 /// </summary> int initx = 0; /// ...
- sencha touch中按钮的ui配置选项值及使用效果