java日志log4j使用

1、导入jar包

log4j-1.2.17.jar

log4j-api-2.0-rc1.jar

log4j-core-2.0-rc1.jar

https://download.csdn.net/download/weixin_44201223/89148839
所需jar包下载地址

2、创建 log4j.properties

src 下创建 log4j.properties (路径和名称都不允许改变),放置 src 下,可以直接加载使用,方便

xml 复制代码
log4j.rootCategory=DEBUG, CONSOLE,LOGFILE
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%C %d{YYYY-MM-dd hh:mm:ss} %m %n
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=log4j.log
#指定打印日志文件所在位置,默认在当前项目目录下
#log4j.appender.LOGFILE.File=D:/log4j.log
#true为追加模式
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%C %m %L %n

3、测试类

java 复制代码
public class TestLog4j {

    public static Logger logger = Logger.getLogger(TestLog4j.class);

    public static void main(String[] args) {
        logger.error("输出error....");
        logger.warn("输出warn....");
        logger.info("输出info....");
        logger.debug("输出debug....");
    }
}

log4j 输出级别

fatal (致命错误) > error (错误) > warn (警告) > info (普通信息) > debug (调试信息)

log4j.properties 的第一行中则是控制输出级别:log4j.rootCategory=INFO, CONSOLE

pattern 常用表达式

%C 包名+类名

%d{YYYY-MM-dd HH:mm:ss} 时间

%L 行号

%m 信息

%n 换行

mybatis_log4j针对dao层设置

settings 常用标签说明

mybatis 全局配置文件中通过 settings 标签来控制 mybatis 的所有全局开关,更多的开启设置查看 mybatis 中文文档。

如 mybatis.xml 中开启 log4j,前提先保证导入 log4jXXX.jar 包, src下创建有log4j.properties 配置文件,然后在mybatis.xml 文件加入开启 log4j 日志使用:

使用前面创建的 mybatis 创建查询连接数据库项目测试,加入 log4j 使用, settings 放置在 environments 前面,如果顺序位置不清楚,可以把鼠标放置在 configuration 标签上查看各类顺序位置:

xml 复制代码
<-- logImpl 可选的值有:SLF4J、LOG4J、LOG4J2、JDK_LOGGING、COMMONS_LOGGING、STDOUT_LOGGING、NO_LOGGING -->
<settings>
	<setting name="logImpl" value="LOG4J"/>
</settings>

在log4j.properties 中可以输出指定内容的日志(控制某个局部内容的日志级别):

命名级别(包级别): namespace 属性中除了最后一个

  • 1.类名
    如 Mapper 映射文件:
    其中包级别为com.mybaties.mapper,需要在 log4j.propeties 中
    • 1).先在总体级别调 Error 不输出无用信息
    • 2).设置某个指定位置级别为 DEBUG
      log4j.rootCategory=ERROR, CONSOLE,LOGFILE
      log4j.logger.com.mybaties.mapper=DEBUG 是指dao层接口的包名称
  • 2.类级别
    namespace 属性值 ,namespace 类名
    log4j.logger.com.mybaties.UserDao=DEBUG
  • 3.方法级别
    使用 namespace 属性值+标签 id 属性值
    log4j.logger.com.mybaties.UserDao.findAll=DEBUG
相关推荐
oioihoii3 分钟前
构造函数和析构函数中的多态陷阱:C++的隐秘角落
java·开发语言·c++
a5876925 分钟前
消息队列(MQ)高级特性深度剖析:详解RabbitMQ与Kafka
java·分布式·面试·kafka·rabbitmq·linq
代码雕刻家31 分钟前
3.1.Maven-课程介绍
java·maven
li357437 分钟前
深入理解:MQ监听类 vs Spring事件监听类 —— 区别、用法与适用场景全解析
java·数据库·spring
灵感蛙1 小时前
《苍穹外卖》项目日记_Day7
java·spring boot·redis
lifallen1 小时前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
索迪迈科技1 小时前
java后端工程师进修ing(研一版‖day42)
java·开发语言·学习·算法
半桔1 小时前
【Linux手册】消息队列从原理到模式:底层逻辑、接口实战与责任链模式的设计艺术
java·linux·运维·服务器
Chris.Yuan7701 小时前
Java代理模式详解
java·开发语言·代理模式
Mr.朱鹏1 小时前
ShardingJDBC实战指南
java·jvm·数据库·spring·分库分表·shardingjdbc·shardingshere