1.rootLogger不输出

代码如下:

配置文件代码:

log4j.rootLogger=info, R,userLog

log4j.appender.R=org.apache.log4j.RollingFileAppender

log4j.appender.R.File=E:/createHtml.log

log4j.appender.R.MaxFileSize=100MB

log4j.appender.R.MaxBackupIndex=20

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

log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%p] %c - %m%n

log4j.appender.userLog=org.apache.log4j.ConsoleAppender

log4j.appender.userLog.Target=System.out

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

log4j.appender.userLog.layout.ConversionPattern=%m%n

类中代码:

private final static Log log = LogFactory.getLog("userInfoLog");

log.debug(“输出日志====”);

错误:设置好的日志,文件中没有输出,控制台也没有输出

原因:level级别问题;配置文件中设置的级别是info;而在类中输出使用的是debug;log4j的level级别为:debugàinfoàwarnàerror;

解决:配置级别高,输出级别低则不会输出,如果反过来就会输出;比如:配置文件改为debug,输出使用log.debug或者log.info或者更高级别都可以。

2.自定义的日志不输出

代码如下:

配置文件代码:

log4j.appender.createExcel=info,excel

log4j.appender.excel=org.apache.log4j.FileAppender

log4j.appender.excel.File=E:/createExcel.log

log4j.appender.excel.Append=true

log4j.appender.excel.Threshold=info

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

log4j.appender.excel.layout.ConversionPattern=%m%n

log4j.additivity.createExcel = false

类中代码:

private final static Log log = LogFactory.getLog("createExcel ");

log.debug(“输出日志====”);

错误:使用自定义的名称createExcel不输出日志

原因:配置文件中的红色代码处有错误,这种错误很容易在配置文件中有很多日志文件的时候,复制上面的出错;

解决:log4j.logger.createExcel=info,excel;Logger:负责供客户端代码调用,执行debug、info等方法。
Appender:负责日志的输出,Log4j已经实现了多种不同目标的输出方式,可以向文件输出日志、向控制台输出日志、向Socket输出日志等。红色部分错误的将logger写成了appender;新添加一个自定义的日志的时候必须要是有log4j.logger类。

扩展:自定义日志的时候还容易出错的地方是:你配置文件中使用自定义名称与类中使用的不一致,这里配置文件中的log4j. appender.createExcel要与类中LogFactory.getLog("createExcel ");一致,否则也会导致不输出日志。

3.
自定义日志使用类名不输出

代码如下:

配置文件代码:

log4j.logger.performanceLogger=INFO,performanceLogger

log4j.appender.performanceLogger=org.apache.log4j.DailyRollingFileAppender             log4j.appender.performanceLogger.File=/application/resinlog/cmslog/common-perf.log

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

log4j.appender.excel.layout.ConversionPattern=%m%n

log4j.additivity.createExcel = false

类中代码:

private final static Log log = LogFactory.getLog (PerformanceMonitorFilter.class);

log.debug(“输出日志====”);

错误:指定的日志文件中没有输出日志,也没有报错

原因:配置文件中使用了自定义名称的方式,但是类中调用日志文件的时候却使用的类名

解决:如果类是个jar包,不容许修改的,那么就把配置文件改了;具体如下:        log4j.logger.com.hudong.keel.web.filter.PerformanceMonitorFilter=INFO,performanceLogger

log4j.appender.performanceLogger=org.apache.log4j.DailyRollingFileAppender

如果类可以改,那也可以不改配置文件直接该类,如下:

private final static Log log = LogFactory.getLog (“performanceLogger”);

扩展:如果你不想在rootLogger指定的文件下输出内容,只想在你知道的自定义文件下输出你的日志,那么你可以把输出开关改为false,默认的是true;如果你不该那么就会在跟日志和你自定义的日志都输出日志;开关如下:

log4j.additivity.createExcel = false

4.如果配置好文件之后再控制台输出一些红色警告,那么证明你配置的log4j文件有错误;检查一下你的配置文件,具体配置文件的使用间博客其他有关log4j使用的文章。

log4j不输出日志错误分析的更多相关文章

  1. 使用log4j无法输出日志

    前段时间在项目的过程中使用log4j来输出日志,但是在一个项目里我明明已经在src/main/resource目录下创建了log4j.properties.具体配置如下: log4j.rootLogg ...

  2. log4j配置输出日志文件

    在测试程序时,有时候运行一次可能需要很久,把日志文件保存下来是很有必要的,本文给出了scala程序输出日志文件的方式,同时使用本人的另一篇博客中介绍的将log4j.properties放到程序jar包 ...

  3. kettle使用log4j管理输出日志

    在使用kettle进行数据分析和清洗时日志非常多而且杂乱,使用原有的日志有时找不到异常的位置,有时日志不够详细,说简单一点就是日志不是我们想要的.因而对kettle日志进行相应的管理就想得尤为重要了. ...

  4. log4j直接输出日志到flume

    log4j.properties配置: log4j.rootLogger=INFOlog4j.category.com.besttone=INFO,flumelog4j.appender.flume ...

  5. Log4j指定输出日志的文件

    在Log4j的配置文件中,有一个log4j.rootLogger用于指定将何种等级的信息输出到哪些文件中, 这一项的配置情况如下: log4j.rootLogger=日志等级,输出目的地1,输出目的地 ...

  6. 排查log4j不输出日志到文件的问题

    问题描述 项目使用Spring Boot框架,在pom文件中添加了如下配置: <dependency> <groupId>org.slf4j</groupId> & ...

  7. log4j不输出日志的解决方案

    参考:http://blog.csdn.net/qq994406030/article/details/53433159 主要是log4j.properties log权限和log输出方式没配好.

  8. log4j日志优先级导致的不输出日志

    在sae部署微信代码的时候,发现它的默认日志很不友好,看起来很费劲,详细看了一下说明发现它可以根据log4j的输出级别而分类输出,就拖了一个log4j的xml文件扔进项目代码,然后部署运行,发现没有日 ...

  9. (OAF)jdeveloper集成log4j并将日志输出到指定文件并写入数据库

    参考: How to configure Log4j in JDev 11g Ever wanted to use log4j in your adf project ? Well though Or ...

随机推荐

  1. 吴裕雄--天生自然 PYTHON3开发学习:运算符

    #!/usr/bin/python3 a = 21 b = 10 c = 0 c = a + b print ("1 - c 的值为:", c) c = a - b print ( ...

  2. App 性能测试

    app常见性能测试点: https://blog.csdn.net/xiaomaoxiao336368/article/details/83547318

  3. JS事件高级

    1. 注册事件(绑定事件) 1.1注册事件概述 1.2 addEventListener 事件监听方式 1.3 attachEvent 事件监听方式 1.4 注册事件兼容性解决方案 2. 删除事件(解 ...

  4. Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之集合类型(set)

    集合!Python中的集合数据基本上是为了方便数学计算使用的. 什么是集合? 集合就是“确定的一堆东西”.集合里面的东西叫做元素. 特点:1. 集合里面是没有重复的元素的.           2. ...

  5. grub.cfg文件编辑

    grub2启动项里面找不到Windows的情况,这时候就需要自己去配置grub.cfg 在grub.cfg中加入如下代码: menuentry 'Windows Boot Manager (on /d ...

  6. Java常见异常说明汇总

    1. java.lang.nullpointerexception 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对 ...

  7. tomcat高并发配置

    最近在项目中负责Tomcat高并发优化方案写一写新得. 优化1)tomcat默认的并发是75,可以启用线程池根据生产环境硬件设定线程池大小. <Executor name="tomca ...

  8. C++ malloc函数

    malloc的全称是memory allocation,中文叫动态内存分配,用于申请一块连续的指定大小的内存块区域以void*类型返回分配的内存区域地址,当无法知道内存具体位置的时候,想要绑定真正的内 ...

  9. php面向对象理解(一)

    常用的继承过程,以及对public.private.protected修饰符的理解: /*****************************父类************************* ...

  10. 吴裕雄--天生自然python学习笔记:python 创建和操作Firebase实时数据库

    Fire base 是专为移动开发提供的后端服务平台, Firebase 数据库与传统数据库不同,它不是用数据表来存储数据, 而是用 Key . Value 的字典型结构来存储数据,所以它不仅 是轻量 ...