log配置详解

使用日志记录信息

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字符,就从左边较远输出的字符截掉。

你可能感兴趣的:([web]架构_运维)