log4j配置
记录一下log4j基础配置
一:基础配置参数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | 每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为: A:off 最高等级,用于关闭所有日志记录。 B:fatal 指出每个严重的错误事件将会导致应用程序的退出。 C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。 D:warm 表明会出现潜在的错误情形。 E:info 一般和在粗粒度级别上,强调应用程序的运行全程。 F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。 G:all 最低等级,用于打开所有日志记录。 上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用 4 个级别,优先级从高到低分别是error,warn,info和debug。 通过使用日志级别,可以控制应用程序中相应级别日志信息的输出。例如,如果使用b了info级别,则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。 appender org.apache.log4j.ConsoleAppender(控制台), org.apache.log4j.FileAppender(文件), org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) 实现自定义Appender继承AppenderSkeleton Log4J最常用的日志输出格式为:org.apache.log4j.PatternLayOut,其主要参数为: %n - 换行 %m - 日志内容 %p - 日志级别(FATAL, ERROR,WARN, INFO,DEBUG or custom) %r - 程序启动到现在的毫秒数 %t - 当前线程名 %d - 日期和时间, 一般使用格式 %d{yyyy-MM-dd HH:mm:ss, SSS} %l - 输出日志事件的发生位置, 同 %F%L%C%M %F - java 源文件名 %L - java 源码行数 %C - java 类名,%C{ 1 } 输出最后一个元素 %M - java 方法名 日志信息格式中几个符号所代表的含义: -X号: X信息输出时左对齐; %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL, %d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似: 2002 年 10 月 18 日 22 : 10 : 28 , 921 %r: 输出自应用启动到输出该log信息耗费的毫秒数 %c: 输出日志信息所属的类目,通常就是所在类的全名 %t: 输出产生该日志事件的线程名 %l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java: 10 ) %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。 %%: 输出一个 "%" 字符 %F: 输出日志消息产生时所在的文件名称 %L: 输出代码中的行号 %m: 输出代码中指定的消息,产生的日志具体信息 %n: 输出一个回车换行符,Windows平台为 "/r/n" ,Unix平台为 "/n" 输出日志信息换行 可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如: 1 )%20c:指定输出category的名称,最小的宽度是 20 ,如果category的名称小于 20 的话,默认的情况下右对齐。 2 )%-20c:指定输出category的名称,最小的宽度是 20 ,如果category的名称小于 20 的话, "-" 号指定左对齐。 3 )%.30c:指定输出category的名称,最大的宽度是 30 ,如果category的名称大于 30 的话,就会将左边多出的字符截掉,但小于 30 的话也不会有空格。 4 )% 20 .30c:如果category的名称小于 20 就补空格,并且右对齐,如果其名称长于 30 字符,就从左边较远输出的字符截掉。 |
二:log4j.properties
log4j.rootLogger = stdout,debug,info,warn,error,jdbc,source log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.out log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern= [%5p] [BYSXXGLXT] %d{yyyy-MM-dd HH:mm:ss}: %-4r [%-5p] [%t] ( %F,%L ) - %m%n log4j.appender.debug = org.apache.log4j.DailyRollingFileAppender log4j.appender.debug.File = log/debug.log log4j.appender.debug.Append = true log4j.appender.debug.Threshold = DEBUG log4j.appender.debug.layout = org.apache.log4j.PatternLayout log4j.appender.debug.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n log4j.appender.info = org.apache.log4j.DailyRollingFileAppender log4j.appender.info.File = log/info.log log4j.appender.info.Append = true log4j.appender.info.Threshold = INFO log4j.appender.info.layout = org.apache.log4j.PatternLayout log4j.appender.info.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n log4j.appender.warn = org.apache.log4j.DailyRollingFileAppender log4j.appender.warn.File = log/warn.log log4j.appender.warn.Append = true log4j.appender.warn.Threshold = WARN log4j.appender.warn.layout = org.apache.log4j.PatternLayout log4j.appender.warn.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n log4j.appender.error = org.apache.log4j.DailyRollingFileAppender log4j.appender.error.File = log/error.log log4j.appender.error.Append = true log4j.appender.error.Threshold = ERROR log4j.appender.error.layout = org.apache.log4j.PatternLayout log4j.appender.error.layout.ConversionPattern = %d{yyyy MMM dd HH:mm:ss} %-5p %c - %m%n #JDBC #log4j.appender.jdbc=org.apache.log4j.jdbc.JDBCAppender #log4j.appender.jdbc.driver=com.mysql.jdbc.Driver #log4j.appender.jdbc.URL=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=true&serverTimezone=UTC #log4j.appender.jdbc.user=root #log4j.appender.jdbc.password= #log4j.appender.jdbc.sql=insert into log_info(level,category,thread,time,location,note) values('%p','%c','%t','%d{yyyy-MM-dd HH:mm:ss:SSS}','%l','%m') log4j.appender.source=com.jachs.log4j.datasource.DataSourceAppender log4j.appender.source.dataSource=dbcp log4j.appender.source.configerfile=/dbcp.properties #log4j.appender.source.dataSource=c3p0 #log4j.appender.source.configerfile=/c3p0.properties log4j.appender.source.sql=insert into log_info(level,category,thread,time,location,note) values(?,?,?,?,?,?) log4j.appender.source.layout = org.apache.log4j.PatternLayout
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)