logger.debug 参数和logger.info方法各自什么作用,两个什么区别

java开发(15)
学习笔记(6)
logger.,logger.warn,logger.error,logger.fatal的作用都是把错误信息写到文本日志里
不同的是它们表示的日志级别不同:
日志级别由高到底是:fatal,error,warn,info,debug,低级别的会输出高级别的信息,高级别的不会输出低级别的
信息,如等级设为Error的话,warn,info,debug的信息不会输出
修改日志输出的级别要在log4j文件中进行配置
项目正式发布后,一般会把日志级别设置为fatal或者error
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:26197次
排名:千里之外
原创:36篇
转载:58篇
(1)(4)(1)(3)(1)(2)(3)(6)(12)(1)(3)(2)(1)(4)(5)(1)(2)(11)(29)(2)博客访问: 1839466
博文数量: 289
博客积分: 5544
博客等级: 大校
技术积分: 5363
注册时间:
  每个人都要有一个骨灰级的爱好, 不为金钱, 而纯粹是为了在这个领域享受追寻真理的快乐.
IT168企业级官微
微信号:IT168qiye
系统架构师大会
微信号:SACC2013
分类: LINUX
一 通过logger命令记录日志
logger 是一个shell 命令接口,可以通过该接口使用Syslog的系统日志模块,还可以从命令行直接向系统日志文件写入一行信息。
日志的级别
facility: auth&&&&&& -用户授权 authpriv&& -授权和安全 cron&&&&&& -计划任务:at ,cron daemon&&&&&-系统守护进程 kern&&&&&& -与内核有关系的信息 lpr&&&&&&& -与打印服务有关的信息。 mail&&&&&& -与电子邮件有关的信息 news&&&&&& -来自新闻服务器的信息 syslog&&&& -由 syslog 生成的信息 user&&&&& &-用户的程序生成的信息,默认。 uucp&&&&&& -由 uucp 生成的信息 local0~7& &-来定义本地策略 level:level定义消息的紧急程度。按严重程度由高到低顺序排列为:emerg =panic(该系统不可用) alert&&& -需要立即采取的动作 crit&&&& -临界状态 err&&&&& -错误状态。等同error warning&&-预警信息,等同warn notice&& -正常但是要注意 info&&&& -正常消息 debug&&&&-调试 none&&&& -一般的信息 1。解决方法:
编辑syslog.conf,
#vi /etc/syslog.conf
在第一行加入local3.none,使得设备local3的日志不记录在messages文件里,
# Log anything (except mail) of level info or higher.
# Don't log private authentication messages!
*.mail.authpriv.cron.local1.local3.none /var/log/messages
将设备local3的所有级别的信息都记录在userlog文件里,
local3.* /var/log/userlog
重新加载syslog服务的配置文件,
$ service syslog reload
测试机器的环境:
OS:Red Hat Enterprise Linux 5 update 3
Network: 192.168.0.100/24 Gateway:192.168.0.1
$&ping 192.168.0.1 | logger -it logger_test -p local3.notice &
命令logger -it logger_test -p local3.notice中的参数含义:
-i 在每行都记录进程ID
-t logger_test 每行记录都加上“logger_test”这个标签
-p local3.notice 设置记录的设备和级别
ping命令的输出成功输出到/var/log/userlog文件中,实验成功。
二 日志回卷
系统时时刻刻都在产生日志,如果不及时清理,很快就会灌满硬盘,但如果要手工清理,又很麻烦。这种情况下,logrotate 这个程序很好的完成这个任务。
logrotate 用来把旧的日志文件删除,并创建新的日志文件,我们把它叫做“转储”。我们可以根据日志文件的大小,也可以根据其天数来转储,这个过程一般通过一个叫做crond的守护进程来执行,logrotate 还可以用于压缩日志文件,以及发送日志到指定的E-mail 。
logrotate 的配置文件是 /etc/logrotate.conf。主要参数如下表:参数 功能compress&&&&&&&&&&&&&&& 通过gzip 压缩转储以后的日志nocompress&&&&&&&&&&&&& 不需要压缩时,用这个参数copytruncate&&&&&&&&&&&&用于还在打开中的日志文件,把当前日志备份并截断nocopytruncate&&&&&&&&& 备份日志文件但是不截断create mode owner group 转储文件,使用指定的文件模式创建新的日志文件nocreate&&&&&&&&&&&&&&& 不建立新的日志文件delaycompress&&&&&&&&&& 和 compress 一起使用时,转储的日志文件到下一次转储时才压缩nodelaycompress&&&&&&&& 覆盖 delaycompress 选项,转储同时压缩。errors address&&&&&&&&& 专储时的错误信息发送到指定的Email 地址ifempty&&&&&&&&&&&&&&&& 即使是空文件也转储,这个是 logrotate 的缺省选项。notifempty&&&&&&&&&&&&& 如果是空文件的话,不转储mail address&&&&&&&&&&& 把转储的日志文件发送到指定的E-mail 地址nomail&&&&&&&&&&&&&&&&& 转储时不发送日志文件olddir directory&&&&&&& 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统noolddir&&&&&&&&&&&&&&& 转储后的日志文件和当前日志文件放在同一个目录下prerotate/endscript&&&& 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行postrotate/endscript&&& 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行daily&&&&&&&&&&&&&&&&&&&指定转储周期为每天weekly&&&&&&&&&&&&&&&&& 指定转储周期为每周monthly&&&&&&&&&&&&&&&& 指定转储周期为每月rotate count&&&&&&&&&&& 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份tabootext [+] list&&&&& 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig .rpmsave size&size&&&&&&&&&&&&&&&当日志文件到达指定的大小时才转储,可以指定bytes(缺省)以及KB(sizek)或者MB (sizem).
系统对 logrotate 的执行和操作:
在/etc/cron.daily/路径下,有一个logrotate 的shell脚本,所以cron程序会每天调用一次logrotate程序,然后logrotate程序回去检查日志文件是否符合回滚条件,并执行相应动作。
执行操作:/usr/sbin/logrotate /etc/cron.daily/logrotate.conf;
在/etc/logrotate.conf文件中,有如下选项:
# RPM packages drop log rotation information into this directory
include /etc/logrotate.d
这个选项说明在执行logrotate程序时,同时执行/etc/logrotated目录下的所有脚本。
执行动作示例:每月清除/var/log/wtmp目录中的相关内容:
/var/log/wtmp {
create 0664 root root
环境: Red Hat Enterprise Linux 5.3
(1)用Cron执行logrotate命令,每分钟检查一次目标日志文件是否满足回卷限制。(2)配置/etc/logrotate.conf 或者建立一个自定义的/etc/logrotate.d /userlog
(3)编辑/etc/syslog.conf 使得记录的日志信息可以写入到/var/log/userlog中。
$&crontab -e
* * * * * /usr/sbin/logrotate /etc/logrotate.conf //写入这条命令
$&vi /etc/logrotate.conf
***省略***
/var/log/userlog {
size 10k ////在这里单位大小写敏感应,应为 k or M
create 0664 root root
/bin/kill -HUP `cat /var/run/syslogd.pid 2> /dev/null` 2> /dev/null
/bin/kill -HUP `cat /var/run/rsyslogd.pid 2> /dev/null` 2> /dev/null
在这里一定要加prerotate这段脚本,这样可以使syslog程序重新读取配置文件,这样做的作用是让syslog程序释放对userlog文件持有的文件描述符,否则即使日志文件回滚,syslog也不会向新产生的日志文件写数据。举个例子,如果不加这段脚本,即使logrotate程序将userlog文件截断并重命名为userlog.1,但是syslog程序仍然会向原userlog文件即userlog.1中写入数据。
$&vi /etc/syslog.conf
*****省略*****
*.mail.authpriv.cron.local1.local3.none /var/log/messages
local3.* /var/log/userlog
重新加载配置文件
$&service syslog reload
重启crond服务
$&service crond restart
需要注意的是,当达到限制条件时,logrotate程序会将目标日志文件userlog截断,并命名为userlog.1,将原userlog.1改名为userlog.2,以此类推,syslog程序始终向userlog文件中写数据。
阅读(7212) | 评论(0) | 转发(1) |
相关热门文章
给主人留下些什么吧!~~
请登录后评论。5926人阅读
Java(103)
原文地址:
第一、Logger.getLogger()和LogFactory.getLog()的区别
&&&&1.Logger.getLogger()是使用log4j的方式记录日志;
&&&&2.LogFactory.getLog()则来自apache的common-logging包。
common-logging组件:&
&&&&&& Jakarta Commons Logging (JCL)提供的是一个日志(Log)接口(interface),同时兼顾轻量级和不依赖于具体的日志实现工具。它提供给中间件/日志工具开发者一个简单的日志操作抽象,允许程序开发人员使用不同的具体日志实现工具。了解包里情况,可以查看它的API文档:&,
其中Log(基本记录器)和LogFactory(负责创建Log实例)是两个基类。该API直接提供对下列底层日志记录工具的支持:Jdk14Logger,Log4JLogger,LogKitLogger,NoOpLogger (直接丢弃所有日志信息),还有一个SimpleLog。 有必要详细说明一下调用LogFactory.getLog()时发生的事情。调用该函数会启动一个发现过程,即找出必需的底层日志记录功能的实现,具体的发现过程在下面列出:&&(&换句话说就是,
有这么多工具,common-logging该使用哪一个呢?这取决于系统的设置,common-logging将按以下顺序决定使用哪个日志记录工具:)
&&&&&&& (1).common-logging首先在CLASSPATH中查找commons-logging.properties文件。这个属性文件至少定义mons.logging.Log属性,它的值应该是上述任意Log接口实现的完整限定名称。如果找到 mons.logging.Log属相,则使用该属相对应的日志组件。结束发现过程。
&&&&&&& (2).如果上面的步骤失败(文件不存在或属相不存在),common-logging接着检查系统属性mons.logging.Log。如果找到mons.logging.Log系统属性,则使用该系统属性对应的日志组件。结束发现过程。
&&&&&&& (3).如果找不到mons.logging.Log系统属性,common-logging接着在CLASSPATH中寻找log4j的类。如果找到了就假定应用要使用的是log4j。不过这时log4j本身的属性仍要通过log4j.properties文件正确配置。结束发现过程。
&&&&&&&&(4).如果上述查找均不能找到适当的Logging API,但应用程序正运行在JRE 1.4或更高版本上,则默认使用JRE 1.4的日志记录功能。结束发现过程。
&&&&&&& (5).最后,如果上述操作都失败(JRE 版本也低于1.4),则应用将使用内建的SimpleLog。SimpleLog把所有日志信息直接输出到System.err。结束发现过程。
&&&&&&& 为了简化配置 commons-logging ,一般不使用 commons-logging 的配置文件,也不设置与 commons-logging 相关的系统环境变量,而只需将 Log4j 的 Jar 包放置到 classpash 中就可以了。这样就很简单地完成了 commons-logging 与 Log4j 的融合。
&&&&&&& 根据不同的性质,日志信息通常被分成不同的级别,从低到高依次是:“调试( DEBUG )”“信息( INFO )”“警告( WARN )”“错误(ERROR )”“致命错误( FATAL )”。
&& 举例说明:
&&&基于common-logging的运行方式:
Java代码&&
package&&&&
import&mons.logging.L&&&
import&org.apache.log4j.L&&&
public&class&Test&extends&TagSupport{&&&
public&static&Log&log=LogFactory.getLog(Test.class);&&&
public&static&void&test()&&&
log.debug(&111&);&&&
(&125&);&&&
log.warn(&485&);&&&
log.error(&error&);&&&
public&static&void&main(String[]&a)&&&
Test.test();&&&
&&&基于log4j的运行方式
Java代码&&
import&org.apache.log4j.L&&&
import&org.apache.log4j.PropertyC&&&
public&class&TestLog4j&{&&&
static&Logger&logger&=&Logger.getLogger(TestLog4j.class);&&&
&&&public&static&void&main(String&args[])&{&&&
&&&PropertyConfigurator.configure(&log4j.properties&);&&&
&&&logger.debug(&Here&is&some&DEBUG&);&&&
&&&(&Here&is&some&INFO&);&&&
&&&&&&logger.warn(&Here&is&some&WARN&);&&&
&&&&&&logger.error(&Here&is&some&ERROR&);&&&
&&&&&&logger.fatal(&Here&is&some&FATAL&);&&&
第二、详细介绍Log4j
&&&①&Log4j的架构&
&& Log4j系统的三大板块:日志写入器、日志输出终端、日志布局模式
&&&&&&& Logger类是日志包的核心,Logger的名称是大小写敏感的,并且名称之间有继承关系。子名由父名做前缀,用点号“.”分隔,如x.y是x.y.z的父亲Logger。Logger系统中有个根logger,是所有logger的祖先,它总是存在的,并且不可以通过名字获取,可以通过Logger.getRootLogger()来获取。获取Logger对象的方法很多,可以参考API文档,在某对象中,用该对象所属的类作为参数,调用Logger.getLogger(Class clazz)以获取logger对象被认为是目前所知最理智的命名logger方法。
&& ②Log4j的日志级别(Level)&
&&&&&& 每个logger都有一个日志级别,用来控制日志的输出。未分配级别的logger将自动继承它最近的父logger的日志级别。Logger的由低到高级别如下:&
&&&& ALL&DEBUG&INFO&WARN&ERROR&FATAL&OFF
&& ③Log4j的输出终端(Appender接口)&
&&&&&&&Log4j提供了以下几个实现:
Java代码&&
org.apache.log4j.ConsoleAppender(控制台)&&&&&
org.apache.log4j.FileAppender(文件)&&&&&
org.apache.log4j.DailyRollingFileAppender(每天都产生一个日志文件)&&&&&
org.apache.log4j.RollingFileAppender(文件大小达到指定尺寸时产生一个新的日志文件,文件名称上会自动添加数字序号。)&&&&&
org.apache.log4j.WriterAppender(将日志信息以流的格式发送到任意指定的地方)&&&&
org.apache.log4j.ConsoleAppender(控制台)&&
org.apache.log4j.FileAppender(文件)&&
org.apache.log4j.DailyRollingFileAppender(每天都产生一个日志文件)&&
org.apache.log4j.RollingFileAppender(文件大小达到指定尺寸时产生一个新的日志文件,文件名称上会自动添加数字序号。)&&
org.apache.log4j.WriterAppender(将日志信息以流的格式发送到任意指定的地方)&&
&&&&& 默认情况下,子logger将继承父logger的所有appenders。
&&&&④Log4j的输出布局模式(Layout接口)&&
&&&&& Log4j提供Layout有以下几种:
Java代码&&
org.apache.log4j.HTMLLayout(以HTML表格形式布局)&&&&&
org.apache.log4j.PatternLayout(可以灵活地指定布局模式)&&&&&
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)&&&&&
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等信息)&&&&
&org.apache.log4j.HTMLLayout(以HTML表格形式布局)&&
&org.apache.log4j.PatternLayout(可以灵活地指定布局模式)&&
&org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)&&
&org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等信息)&&
&&&& Log4j采用类似C语言中的printf函数的打印格式格式化日志信息。打印参数如下:
Html代码&&
%m:输出代码中指定的消息。&&&&&
%p:输出优先级。&&&&&
%r:输入自应用启动到输出该log信息耗费的毫秒数。&&&&&
%c:输出所属的类目,通常就是所在类的全名。&&&&&
%n:输出一个回车换行符。Windows平台为“\r\n”,UNIX为“\n”。&&&&&
%d:输出日志时间点的日期或时间,默认格式为ISO8601,推荐使用“%d{ABSOLUTE}”,这个输出格式形如:“&18:23:23,500”,符合中国人习惯。&&&&&
%l:输出日志事件发生的位置,包括类名、线程名,以及所在代码的行数。&&&&
%m:输出代码中指定的消息。&&
%c:输出所属的类目,通常就是所在类的全名。&&
%t:输出产生该日志线程的线程名。&&
%n:输出一个回车换行符。Windows平台为“\r\n”,UNIX为“\n”。&&
%d:输出日志时间点的日期或时间,默认格式为ISO8601,推荐使用“%d{ABSOLUTE}”,这个输出格式形如:“&18:23:23,500”,符合中国人习惯。&&
%l:输出日志事件发生的位置,包括类名、线程名,以及所在代码的行数。&&
%d&输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd&HH:mm:ss&},输出类似:-&22:10:28&&
%f&输出日志信息所属的类的类名&&
%l&输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行&&
%m&输出代码中指定的信息,如log(message)中的message&&
%p&输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推&&
%r&输出自应用启动到输出该日志信息所耗费的毫秒数&&
%t&输出产生该日志事件的线程名&&
&&&⑤Log4j的配置
&&&&在实际使用中,Log4j一般是通过配置文件配置使用的。配置文件有两种,Java properties和XML文件。一般都选用properties文件来配置,因为简洁易读。下面只介绍Java properties的配置方式。&
对Log4j的配置就是对rootLogger和子Logger的配置。主要的配置项为:rootLogger、输出终端、输出布局模式,所有的配置项都必须以log4j开头。&
&&& 配置文件的示例
Java代码&&
##Log4J的配置之简单使它遍及于越来越多的应用中了&&&&&
##Log4J配置文件实现了输出到控制台、文件、回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了。&&&&&
##此文件(log4j.properties)内容来自网络,非本文作者liigo原创。&&&&&
log4j.rootLogger&=&DEBUG,&CONSOLE,A1&&&&&
log4j.addivity.org.apache&=&true&&&&
#&应用于控制台&&&&&
log4j.appender.CONSOLE&=&org.apache.log4j.ConsoleAppender&&&&&
log4j.appender.Threshold&=&DEBUG&&&&&
log4j.appender.CONSOLE.Target&=&System.out&&&&&
log4j.appender.CONSOLE.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.CONSOLE.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
#log4j.appender.CONSOLE.layout.ConversionPattern&=&[start]&%&d&{DATE}&[DATE]&%&n&%&p[PRIORITY]&%&n&%&x[NDC]&%&n&%&t[THREAD]&n&%&c[CATEGORY]&%&n&%&m[MESSAGE]&%&n&%&n&&&&&
#应用于文件&&&&&
log4j.appender.FILE&=&org.apache.log4j.FileAppender&&&&&
log4j.appender.FILE.File&=&file.log&&&&&
log4j.appender.FILE.Append&=&false&&&&
log4j.appender.FILE.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.FILE.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
#&Use&this&layout&for&LogFactor&5&analysis&&&&&
#&应用于文件回滚&&&&&
log4j.appender.ROLLING_FILE&=&org.apache.log4j.RollingFileAppender&&&&&
log4j.appender.ROLLING_FILE.Threshold&=&ERROR&&&&&
log4j.appender.ROLLING_FILE.File&=&rolling.log&&&&&
log4j.appender.ROLLING_FILE.Append&=&true&&&&
log4j.appender.ROLLING_FILE.MaxFileSize&=&10KB&&&&&
log4j.appender.ROLLING_FILE.MaxBackupIndex&=&1&&&&
log4j.appender.ROLLING_FILE.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.ROLLING_FILE.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
#应用于socket&&&&&
log4j.appender.SOCKET&=&org.apache.log4j.RollingFileAppender&&&&&
log4j.appender.SOCKET.RemoteHost&=&localhost&&&&&
log4j.appender.SOCKET.Port&=&5001&&&&
log4j.appender.SOCKET.LocationInfo&=&true&&&&
#&Set&up&for&Log&Facter&5&&&&
log4j.appender.SOCKET.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.SOCET.layout.ConversionPattern&=&[start]&%&d&{DATE}&[DATE]&%&n&%&p[PRIORITY]&%&n&%&x[NDC]&%&n&%&t[THREAD]&%&n&%&c[CATEGORY]&%&n&%&m[MESSAGE]&%&n&%&n&&&&&
#&Log&Factor&5&Appender&&&&&
log4j.appender.LF5_APPENDER&=&org.apache.log4j.lf5.LF5Appender&&&&&
log4j.appender.LF5_APPENDER.MaxNumberOfRecords&=&2000&&&&
#&发送日志给邮件&&&&&
log4j.appender.MAIL&=&org.apache.log4j.net.SMTPAppender&&&&&
log4j.appender.MAIL.Threshold&=&FATA&&&&&
log4j.appender.MAIL.BufferSize&=&10&&&&
log4j.appender.MAIL.From&=&web@www.&&&&&
log4j.appender.MAIL.SMTPHost&=&&&&&&
log4j.appender.MAIL.Subject&=&Log4J&Message&&&&&
log4j.appender.MAIL.To&=&web@www.&&&&&
log4j.appender.MAIL.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.MAIL.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
#&用于数据库&&&&&
log4j.appender.DATABASE&=&org.apache.log4j.jdbc.JDBCAppender&&&&&
log4j.appender.DATABASE.URL&=&jdbc:mysql:&&&
log4j.appender.DATABASE.driver&=&com.mysql.jdbc.Driver&&&&&
log4j.appender.DATABASE.user&=&root&&&&&
log4j.appender.DATABASE.password&=&&&&&
log4j.appender.DATABASE.sql&=&INSERT&INTO&LOG4J&(Message)&VALUES&(&'&[framework]&%d&-&%c&-%-4r&[%t]&%-5p&%c&%x&-&%m%n&'&)&&&&&
log4j.appender.DATABASE.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.DATABASE.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
log4j.appender.A1&=&org.apache.log4j.DailyRollingFileAppender&&&&&
log4j.appender.A1.File&=&SampleMessages.log4j&&&&&
log4j.appender.A1.DatePattern&=&yyyyMMdd&-&HH&'&.log4j&'&&&&
log4j.appender.A1.layout&=&org.apache.log4j.xml.XMLLayout&&&&&
#自定义Appender&&&&&
log4j.appender.im&=&net.cybercorlin.util.logger.appender.IMAppender&&&&&
log4j.appender.im.host&=&mail.cybercorlin.net&&&&&
log4j.appender.im.username&=&username&&&&&
log4j.appender.im.password&=&password&&&&&
log4j.appender.im.recipient&=&corlin@cybercorlin.net&&&&&
log4j.appender.im.layout&=&org.apache.log4j.PatternLayout&&&&&
log4j.appender.im.layout.ConversionPattern&=&[framework]&%&d&-&%&c&-%-&4r&[&%&t]&%-&5p&%&c&%&x&-&%&m&%&n&&&&&
#&结束&&&&
&本文内容来自于好几位网友的博客,在此对他们表示感谢
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:780963次
积分:7599
积分:7599
排名:第2315名
原创:36篇
转载:449篇
评论:41条
(1)(3)(1)(3)(1)(4)(1)(1)(1)(36)(2)(4)(17)(21)(21)(53)(16)(40)(19)(32)(4)(24)(27)(16)(17)(12)(2)(34)(3)(18)(7)(3)(2)(5)(8)(7)(7)(2)(3)(7)(1)(1)&logger.debug-学网-提供健康,养生,留学,移民,创业,汽车等信息
&logger.debug
你好,这句代码的意思就是在执行init(初始化方法)的时候,将&CarInsuranceCustomerManage..jsp页面初始化开始.....&这句字符串做为debug(调试)写入日志。private static final Logger logger = Logger.getLogger(Avatar.class); logger.debug(&在这里输入&); 基本就是这样,没什么难度。看结构,应该是BaseFunction&类有个静态成员&loggerlogger&有方法&debug这个代码的意思是,输出一个调试级别的语句(在debug&级别才输出)"**C...一个是Debug级别的日志,一个是记录Info级别的日志,两者的日志详细程度不同,相比Info只需记录日常日志,Debug日志用于开发人员Debug使用,所以需记录详细的业务流程 所以你可能会加logger.debug。 为什么是debug而不是info error或者其他呢?因为通常项目发布的时候都会把日志等级设置为error 或者info之类的等级,在这两个等级下debug的...实例如下: &代码如下: var log = new Logger('***.js') if (log.isDebugEnabled()) { & & & & & & & & & & log.debug('xxxxx...logger(logger.LEVEL_DEBUG, null, logger.VIEW_TYPE_APPEND); })(); 怎么使用呢? 这个js组件往window对象注册了Logger对象,我们可以用Logger.log/Logger.debug/Log...变量是被static修饰的方法/变量,为类方法/变量,也可以用实例访问 Logger 是某个静态类,这个类里面应该有一个logger属性,该属性对应的get和set方法,Logger.getL...用log工具咯,例如:log4j,大概是这样的: logger.debug(&出现异常&, ex); 想在哪里输出都可以配置,而且可以配置异常级别,比如debug、warn等等!!debug& /& &logger name=&java.sql.Connection& level=&debug& /& &logger name=&java.sql.Statement& level=&debug& /...
您可能还关注:&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
大类导航: |}

我要回帖

更多关于 logger.debug 不输出 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信