您的位置:首页 > 其它

Log日志详解分析

2016-07-02 23:22 295 查看
使用日志记录信息

1、关于日志级别

日志可分为五个级别

DEBUG :为程序的调试信息,最低级

INFO :为一般要显示的信息,比如登录登出

ERROR:为严重错误 主要是程序的错误

WARN :为一般警告,比如session丢失

FATAL:崩溃,整个程序终止运行

 

2、将日志输出到指定的地方

1.输出到文件

log4j.rootLogger=debug,tofile

#输出到文件

log4j.appender.toFile=org.apache.log4j.FileAppender

#按指定的格式输出

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

#指定输出格式

log4j.appender.toFile.layout.ConversionPattern=%d %p [%c %M] %m %n

#指定文件输出文件路径

log4j.appender.toFile.file=log/b.txt

 

3.输出到数据库

lo4j.rootLogger=debug,toJDBC

#输出到数据库

log4j.appender.toJDBC=org.apache.log4j.jdbc.JDBCAppender

#指明输出的格式

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

#数据源在数据库输出格式

log4j.appender.toJDBC.layout.ConversionPattern=%d %p [%c %M] %m %n

#指明驱动

log4j.appender.toJDBC.driver=net.sourceforge.jtds.jdbc.Driver

#数据库URL

log4j.appender.toJDBC.URL=jdbc:jtds:sqlserver://localhost:1433/pet

#数据库用户名

log4j.appender.toJDBC.user=sa

#数据库密码

log4j.appender.toJDBC.password=sa

#指定数据库sql语句

log4j.appender.toJDBC.sql=insert into loginfo(log4jinfo) values('%d %p [%c %M] %m %n')

 

4.输出到控制台

输出的是调试的信息

#log4j.rootLogger=debug,toCon,

#配置Appendder的全路径ConsoleAppender:输出到控制台

log4j.appender.toCon=org.apache.log4j.ConsoleAppender

#说明输出的格式:SimpleLayout 简单格式,只有信息和级别的输出

log4j.appender.toCon.layout=org.apache.log4j.SimpleLayout

 

5.输出到网页

log4j.rootLogger=debug,html

#输出到HTML

log4j.appender.html=org.apache.log4j.DailyRollingFileAppender

#按指定的格式输出

log4j.appender.html.layout=org.apache.log4j.HTMLLayout

#指定输出格式

#log4j.appender.toFile.layout.ConversionPattern=%d %p [%c %M] %m %n

#指定文件输出文件路径

log4j.appender.html.file=Html/b.html

 

6、相关操作

设置输出级别

1.private Logger log = Logger.getLogger(Log4jTest.class);

2.log.setlevel(Level.WARN)


7、日志信息格式中符号的作用


-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"输出日志信息换行

8、可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:

1) c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。

2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。

3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。

4) .30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  log 日志