log4j使用

为什么要学log4j
1. 如果项目需要日志系统,需要使用log4j输出日志
2. hiberante、mybatis等框架可以修改log4j的日志级别来输出日志

准备: 下载log4j-1.2.17

log4j使用:

  1. 、导入包
  2. 创建Logger对象,创建类UserDao
    //创建Logger对象
    public static final Logger logger = Logger.getLogger(UserDao.class);
    3.编写相应的日志
    /**
    * 可以为日志设定不同的级别,在log4j中
    * debug<info<warn<error<fatal
    * 如何设置info级别,那么debug日志不输出
    */
    logger.debug(“添加了用户信息”);
    logger.info(“添加了用户信息”);
    logger.warn(“添加了用户信息”);
    logger.error(“添加了用户信息”);
    logger.fatal(“添加了用户信息”);

4.4、src创建log4j.properties
编写日志的配置文件,以此说明日志的显示方式和级别(在src中创建log4j.properties文件)
4.1、首先创建Append
log4j.appender.stout=org.apache.log4j.ConsoleAppender
创建了一个appender名称叫做stout,使用的类型是ConsoleAppender,ConsoleAppender是Appender的子类,可以是控制台、文件、数据库、网络流
4.2、说明展示的布局
log4j.appender.stout.layout=org.apache.log4j.PatternLayout,
说明Appender使用哪种布局来展示,常用的是PatternLayout来展示
4.3、说明通过什么样的格式来完成展示
log4j.appender.stout.layout.ConversionPattern=%p–>%m(%d)
使用的格式是什么级别的日志–>日志信息(日志的时间)
Appender可以查看文档:这里写图片描述

对应不同的Appender可以日志输出到不同位置:
我这里定义了两个,一个是控制台,一个是基于日期的滚动,

控制台

log4j.appender.stout=org.apache.log4j.ConsoleAppender
log4j.appender.stout.layout=org.apache.log4j.PatternLayout
log4j.appender.stout.layout.ConversionPattern=%p–>%m(%d)%n

文件

log4j.appender.fout = org.apache.log4j.DailyRollingFileAppender
log4j.appender.fout.datePattern=’.’yyyy-MM-dd
log4j.appender.fout.file = ${LOG_DIR}/user.log
log4j.appender.fout.layout=org.apache.log4j.PatternLayout
log4j.appender.fout.layout.ConversionPattern=%p–>%m%n

5、在什么时候输出日志
log4j.rootLogger=DEBUG, stout
rootLogger是根目录的Logger,每一个项目的classpath就是根目录,只要运行到输出日志的位置,并且日志的级别大于
DEBUG就会输出。rootLogger表示的就是执行的任意一个类只要有大于DEBUG的日志就会输出,会调用stout这个Appender输出

还可以log4j.logger.mylogger4jproject = DEBUG,stout,fout
指定mylogger4jproject 这个包,下使用stout,fout来输出,一个logger可以对应多个appende
6.
调用:
public static void main(String[] args) {
// 替换日志输出路径,把日志输出在bin下
String url = TestLog.class.getClassLoader().getResource(“”).getPath();
url = url.replace(“bin/”, “log”);
System.setProperty(“LOG_DIR”, url);

    UserDao userDao=new UserDao();

        userDao.add();


}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值