log4j详细配置

参考博客:https://blog.csdn.net/sinat_30185177/article/details/73550377

log4j。。很简单好用的一个记录日志的东东,正因为好用,本人从来没有亲自配置过(都是别人在项目里面配好的,直接copy过来用),但是最近进了一家新公司,(或许因为某些原因)他们封装了一个日志工具类日志打印特定的信息,因为此项目以后由我接手,所以我做主就后来改了日志打印方式,原本代码如下:

此方式称之为方法一..

public class LogTool {

    public static void debugSysLog(String logtext) {
        writeLog(logtext,"info");
        System.out.println(logtext);
    }

    static Logger log = Logger.getLogger(LogTool.class);

    public static void writeLog(String msg,String level){
        if(level.equals("debug"))
            log.debug(msg);
        else if(level.equals("error"))
            log.error(msg);
        else if(level.equals("warn"))
            log.warn(msg);
        else
            log.info(msg);
    }
}

log4j.properties的代码:

log4j.rootLogger=INFO,logfile,stdout,DEBUG

#输出到控制台
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c]:%l - %m%n

#log4j.appender.logfile=org.apache.log4j.FileAppender
#log4j.appender.logfile=org.apache.log4j.RollingFileAppender#log4j.appender.logfile.MaxFileSize=1MB

#输出到文件
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.DatePattern=‘.‘yyyy-MM-dd

log4j.appender.logfile.File=${catalina.home}/webapps/logs/invoice.log

#log4j.appender.logfile.MaxBackupIndex=20
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p : %l - %m%n

上面的log4j配置文件我已经修改过了,原本的是不打印错误信息的,即下面的一些东东记一下就行了。
#%m   输出代码中指定的消息
#%p   输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
#%r   输出自应用启动到输出该log信息耗费的毫秒数
#%c   输出所属的类目,通常就是所在类的全名
#%t   输出产生该日志事件的线程名
#%n   输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n”
#%d   输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日  22:10:28
#%l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java: 10 )

使用工具类打印的信息如上图红色部分(很整洁,漂亮,,有乱用??有一次项目报错空指针,都不知道哪里错的。。)

方法二:

使用同样的配置文件,在项目里面使用如下代码打印日志,会提示的很完整,且方法一能实现的方法二都可以实现..
Logger log = Logger.getLogger(InvoiceBuildServlet.class);

在catch里面用 log.error("error",e);

很简单。。

下面是配置文件源文件的下载地址

https://files.cnblogs.com/files/haopengchen/log4j.properties.zip

原文地址:https://www.cnblogs.com/haopengchen/p/9209386.html

时间: 2024-11-13 12:13:46

log4j详细配置的相关文章

log4j 详细配置实例

一,maven引入jar包 org.slf4j slf4j-api 1.6.6 org.slf4j slf4j-log4j12 1.6.6 log4j log4j 1.2.17 # 二,详细配置: ### root日志 ### log4j.rootLogger = DEBUG, stdout, debug, info , warn, error #控制台日志 log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender

Log4j.properties配置详细解读

Log4j.properties配置 Log4j有三个主要的组件:Loggers(记录器),Appenders  (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使用这三个组件可以轻松地记录信息的类型和级别,并可以在运行时控制日志输出的样式和位置. 1.Loggers Loggers组件在系统中被分为五个级别:DEBUG.INFO.WARN.ERROR和FATAL.这五个级别是有顺序的,DEBUG < INFO < WARN < E

springmvc+log4j操作日志记录,详细配置

没有接触过的,先了解一下:log4j教程 部分内容来:log4j教程 感谢! 需要导入包: log包:log4j-12.17.jar 第一步:web.xml配置 <!-- log4j配置,文件路径,因为是跟随项目启动 --> <context-param> <param-name>log4jConfigLocation</param-name> <param-value>/WEB-INF/log4j.xml</param-value>

(转)springMVC+mybatis+ehcache详细配置

一. Mybatis+Ehcache配置 为了提高MyBatis的性能,有时候我们需要加入缓存支持,目前用的比较多的缓存莫过于ehcache缓存了,ehcache性能强大,而且位各种应用都提供了解决方案,在此我们主要是做查询缓存,提高查询的效率. 整合MyBatis和ehcache需要的jar包如下: ehcache-core-2.4.4.jar mybatis-ehcache-1.0.0.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.2.jar 资源已上传

springMVC+mybatis+ehcache详细配置

一. Mybatis+Ehcache配置 为了提高MyBatis的性能,有时候我们需要加入缓存支持,目前用的比较多的缓存莫过于ehcache缓存了,ehcache性能强大,而且位各种应用都提供了解决方案,在此我们主要是做查询缓存,提高查询的效率. 整合MyBatis和ehcache需要的jar包如下: ehcache-core-2.4.4.jar mybatis-ehcache-1.0.0.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.2.jar 资源已上传

热切换Log4j级别配置

欢迎和大家交流技术相关问题:邮箱: [email protected]博客园地址: http://www.cnblogs.com/jiangxinnjuGitHub地址: https://github.com/jiangxincode知乎地址: https://www.zhihu.com/people/jiangxinnju 做一个产品或者项目,在测试时一般要打印详细的log,发布以后,因为打印日志会损失性能,所以通常在生产机上将log4j级别设置为最高,以提高效率,一旦客户那里出了问题,需要查

java log4j基本配置及日志级别配置详解

java log4j日志级别配置详解 1.1 前言 说出来真是丢脸,最近被公司派到客户公司面试外包开发岗位,本来准备了什么redis.rabbitMQ.SSM框架的相关面试题以及自己做过的一些项目回顾,信心满满地去面试,结果别人一上来就问到了最近项目使用的日志系统是什么?日志级别是怎么配置的?当时我都蒙X了,平时都是项目经理搭的,我自己也是随便上网一搜往配置文件一黏贴就OK了.我就这么说完后面试官深深定了我一眼,当时我的内心羞愧到...... 1.2 闲话少说,讲讲日志的发展故事(如果已经了解的

Vsftpd 详细配置

Vsftpd 详细配置         目    录 1.配置文件 2.给匿名用户的配置 3.系统用户配置 4.禁锢所有ftp系统用户在家目录中 5.禁锢或不禁锢特定的系统用户在家目录中,与上面设置互斥 6.wu-ftp日志 7.vsftpd日志 8.登录提示信息 9.目录访问提示信息 10.使用pam完成用户认证 11.是否启用控制用户登录的列表文件 12.连接限制 13.传输速率 :字节/秒 14.连接时间:秒为单位 15.优先以文本方式传输 16.其他参数 Vsftpd服务有vsftpd包

Log4j:log4j.properties 配置解析

Log4j 三个主要组件 Loggers(记录器):记录日志的工具,程序中就是用它来记录我们想要的日志信息. Appenders (输出源):日志输出到什么地方,可以是控制台.文件.流位置.数据库,等等. Layouts(布局模式):日志需要记录哪些基本信息,用什么样的格式去记录展示这些信息. 一个 Logger 最少要有一个 Appender,一个 Appender 有一个 Layout. Loggers 记录器在 Log4j 中就是 Logger 类的实例对象,下面是该类中定义的一些主要方法