java中日志的级别说明

部署运行你感兴趣的模型镜像

log4j定义了8个级别的log(除去OFF和ALL,可以说分为6个级别),优先级从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。

log4j规定了默认的几个级别:trace<debug<info<warn<error<fatal等。这里要说明一下:

1)级别之间是包含的关系,意思是如果你设置日志级别是trace,则大于等于这个级别的日志都会输出。

2)基本上默认的级别没多大区别,就是一个默认的设定。你可以通过它的API自己定义级别。你也可以随意调用这些方法,不过你要在配置文件里面好好处理了,否则就起不到日志的作用了,而且也不易读,相当于一个规范,你要完全定义一套也可以,不用没多大必要。

  • ALL:最低等级的,用于打开所有日志记录。

  • TRACE(追踪): 就是程序推进一下,你就可以写个trace输出,所以trace应该会特别多,不过没关系,我们可以设置最低日志级别不让他输出。

  • DEBUG: 指出细粒度信息事件对调试应用程序是非常有帮助的,主要用于开发过程中打印一些运行信息。

  • INFO: 消息在粗粒度级别上突出强调应用程序的运行过程。打印一些你感兴趣的或者重要的信息,这个可以用于生产环境中输出程序运行的一些重要信息,但是不能滥用,避免打印过多的日志。

  • WARN: 表明会出现潜在错误的情形,有些信息不是错误信息,但是也要给程序员的一些提示。

  • ERROR: 指出虽然发生错误事件,但仍然不影响系统的继续运行。打印错误和异常信息,如果不想输出太多的日志,可以使用这个级别。

  • FATAL: 指出每个严重的错误事件将会导致应用程序的退出。这个级别比较高了。重大错误,这种级别你可以直接停止程序了。

  • OFF: 最高等级的,用于关闭所有日志记录。

如果将log level设置在某一个级别上,那么比此级别优先级高的log都能打印出来。例如,如果设置优先级为WARN,那么OFF、FATAL、ERROR、WARN 4个级别的log能正常 输出,而INFO、DEBUG、TRACE、 ALL级别的log则会被忽略。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。

从我们实验的结果可以看出,log4j默认的优先级为ERROR或者WARN(实际上是ERROR)。

日志调用demo

import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class Hello {

    static Logger logger = LogManager.getLogger(Hello.class.getName());

    public boolean hello() {
        logger.entry();   //trace级别的信息,单独列出来是希望你在某个方法或者程序逻辑开始的时候调用,和logger.trace("entry")基本一个意思
        logger.error("Did it again!");   //error级别的信息,参数就是你输出的信息
        logger.info("我是info信息");    //info级别的信息
        logger.debug("我是debug信息");
        logger.warn("我是warn信息");
        logger.fatal("我是fatal信息");
        logger.log(Level.DEBUG, "我是debug信息");   //这个就是制定Level类型的调用:谁闲着没事调用这个,也不一定哦!
        logger.exit();    //和entry()对应的结束方法,和logger.trace("exit");一个意思
        return false;
    }
}  
<?xml version="1.0" encoding="UTF-8"?>
<configuration status="info">
	<Properties>
		<!-- 根目录 -->
		<Property name="baseDir">log</Property>
		<!-- 保存最近N天 ,单位:d m y,注意:设置的天数比实际保存的天数多一天,例如设置7d,则实际保存的天数为8d. -->
		<Property name="saveDays">30d</Property>
		<!-- 每一类文件最大压缩个数 -->
		<Property name="fileCountPerCategory">200</Property>
		<!-- 每一类文件大小 单位:KB MB GB ,例如:50 MB -->
		<Property name="fileSizePerCategory">50 MB</Property>
		<!-- 日志开头输出内容格式 -->
		<Property name="globalPatternLayout">%d %-5p %m%n %ex</Property>
		<Property name="filePatternLayout" >%-d [%t] %-5p %c %L - %m%n %ex</Property>
		<!-- 全局日志级别 -->
		<Property name="loglevel">info</Property>
	</Properties>

	<appenders>
<!-- %-5p row: %L, time: %-4r %m%n -->
		<Console name="STDOUT" target="SYSTEM_OUT">
			<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${globalPatternLayout}" />
		</Console>

		<RollingFile name="TASK_DEBUG"
			fileName="${baseDir}/task_debug.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_debug-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>

		<RollingFile name="TASK_RESULT"
			fileName="${baseDir}/task_result.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_result-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_result-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
		<RollingFile name="TASK_DOWNLOAD"
					 fileName="${baseDir}/task_download.log"
					 filePattern="${baseDir}/$${date:yyyyMMdd}/task_download-%d{yyyy-MM-dd}-%i.log.zip"
		><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_download-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
										exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
		<RollingFile name="TASK_OPERATE"
			fileName="${baseDir}/task_operate.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_operate-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_operate-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
			
		</RollingFile>
		<RollingFile name="TASK_ERROR"
			fileName="${baseDir}/task_error.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_error-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_error-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
		<RollingFile name="TASK_SQL"
			fileName="${baseDir}/task_sql.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_sql-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_sql-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
		<RollingFile name="TASK_HANDLE"
			fileName="${baseDir}/task_handle.log"
			filePattern="${baseDir}/$${date:yyyyMMdd}/task_handle-%d{yyyy-MM-dd}-%i.log.zip"
			><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_handle-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
									exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
		<!--mos ssm sdk-->
		<RollingFile name="MOSSDK"
					 fileName="${baseDir}/task_mossdk.log"
					 filePattern="${baseDir}/$${date:yyyyMMdd}/task_mossdk-%d{yyyy-MM-dd}-%i.log.zip"
		><!--filePattern="${baseDir}/$${date:yyyyMMdd}/task_debug-%d{yyyy-MM-dd}-%i.log.gz" -->
			<PatternLayout pattern="${filePatternLayout}" />
			<Policies>
				<TimeBasedTriggeringPolicy modulate="true" interval="1" />
				<SizeBasedTriggeringPolicy size="${fileSizePerCategory}" />
			</Policies>
			<DefaultRolloverStrategy max="${fileCountPerCategory}">
				<Delete basePath="${baseDir}" maxDepth="2">
					<IfFileName glob="*/task_operate-*.log.gz">
						<IfLastModified age="${saveDays}">
							<IfAny>
								<IfAccumulatedFileSize
										exceeds="${fileSizePerCategory}" />
								<IfAccumulatedFileCount exceeds="2" />
							</IfAny>
						</IfLastModified>
					</IfFileName>
				</Delete>
			</DefaultRolloverStrategy>
		</RollingFile>
	</appenders>

	<loggers>

		<AsyncLogger name="com.rootnet" level="debug"
			includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_DEBUG" />
			<AppenderRef ref="TASK_ERROR" />
		</AsyncLogger>
		<AsyncLogger name="TASK_OPERATE" level="info" includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_OPERATE" />
		</AsyncLogger>
		<!-- 记录操作日志结束 -->

	<!-- 输出屏幕结果日志 -->
		<AsyncLogger name="TASK_RESULT" level="info"
			includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_RESULT" />
		</AsyncLogger>

		<AsyncLogger name="TASK_DOWNLOAD" level="info"
					 includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_DOWNLOAD" />
		</AsyncLogger>

		<!-- SQL日志 com.ibatis.sqlmap.engine.impl.SqlMapClientImpl -->
		
		 <!--<AsyncLogger name="java.sql" level="debug"
			includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_SQL" />
			<appender-ref ref="STDOUT" />
		</AsyncLogger> -->
		<AsyncLogger name="java.sql.PreparedStatement" level="debug"
			  additivity="false">
			<AppenderRef ref="TASK_SQL" />
		</AsyncLogger>
			<AsyncLogger name="java.sql.Statement" level="debug"
			  additivity="false">
			<AppenderRef ref="TASK_SQL" />
		</AsyncLogger>	
		<AsyncLogger name="java.sql.ResultSet" level="debug"
			  additivity="false">
			<AppenderRef ref="TASK_SQL" />
		</AsyncLogger>
		<!-- 每笔详细信息 -->
		<AsyncLogger name="com.rootnet.stocksync.handle" level="debug"
			includeLocation="false" additivity="false">
			<AppenderRef ref="TASK_HANDLE" />
		</AsyncLogger>
		
		<AsyncRoot level="debug" includeLocation="false">
			<appender-ref ref="STDOUT" />
			<appender-ref ref="TASK_DEBUG" />
		</AsyncRoot>

		<!--mos ssm sdk-->
		<AsyncLogger name="sdk.postmsg" level="debug"
					 additivity="false">
			<AppenderRef ref="MOSSDK" />
		</AsyncLogger>
		<AsyncLogger name="sdk.postmsg.comm" level="debug"
					 additivity="false">
			<AppenderRef ref="MOSSDK" />
		</AsyncLogger>
		<AsyncLogger name="sdk.postmsg.biz" level="debug"
					 additivity="false">
			<AppenderRef ref="MOSSDK" />
		</AsyncLogger>
	</loggers>

</configuration>

先简单介绍一下下面这个配置文件。

1)根节点configuration,然后有两个子节点:appenders和loggers(都是复数,意思就是可以定义很多个appender和logger了)(如果想详细的看一下这个xml的结构,可以去jar包下面去找xsd文件和dtd文件)

2)appenders:这个下面定义的是各个appender,就是输出了,有好多类别,这里也不多说(容易造成理解和解释上的压力,一开始也未必能听懂,等于白讲),先看这个例子,只有一个Console,这些节点可不是随便命名的,Console就是输出控制台的意思。然后就针对这个输出设置一些属性,这里设置了PatternLayout就是输出格式了,基本上是前面时间,线程,级别,logger名称,log信息等,差不多,可以自己去查他们的语法规则。

3)loggers下面会定义许多个logger,这些logger通过name进行区分,来对不同的logger配置不同的输出,方法是通过引用上面定义的logger,注意,appender-ref引用的值是上面每个appender的name,而不是节点名称。

配置文件中name的机制

我们上面的这个配置文件里面还定义了一个logger,他的名称是 cn.lsw.base.log4j2.Hello ,这个名称其实就是通过前面的Hello.class.getName(); 得到的,我们为了给他单独做配置,这里就生成对于这个类的logger,上面的配置基本的意思是只有cn.lsw.base.log4j2.Hello 这个logger输出trace信息,也就是他的日志级别是trace,其他的logger则继承root的日志配置,日志级别是error,只能打印出ERROR及以上级别的日志。如果这里logger 的name属性改成cn.lsw.base,则这个包下面的所有logger都会继承这个log配置(这里的包是log4j的logger name的“包”的含义,不是java的包,你非要给Hello生成一个名称为“myhello”的logger,他也就没法继承cn.lsw.base这个配置了。

那有人就要问了,他不是也应该继承了root的配置了么,那么会不会输出两遍呢?我们在配置文件中给了解释,如果你设置了additivity=“false”,就不会输出两遍,

一个复杂的例子

<?xml version="1.0" encoding="UTF-8"?>

<configuration status="error">
    <!--先定义所有的appender-->
    <appenders>
        <!--这个输出控制台的配置-->
        <Console name="Console" target="SYSTEM_OUT">
            <!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
            <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
            <!--这个都知道是输出日志的格式-->
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </Console>
        <!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用-->
        <File name="log" fileName="log/test.log" append="false">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </File>

        <!--这个会打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档-->
        <RollingFile name="RollingFile" fileName="logs/app.log"
                     filePattern="log/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz">
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <SizeBasedTriggeringPolicy size="50MB"/>
        </RollingFile>
    </appenders>
    <!--然后定义logger,只有定义了logger并引入的appender,appender才会生效-->
    <loggers>
        <!--建立一个默认的root的logger-->
        <root level="trace">
            <appender-ref ref="RollingFile"/>
            <appender-ref ref="Console"/>
        </root>

    </loggers>
</configuration>

参考文章:https://www.cnblogs.com/leo-lsw/p/log4j2tutorial.html

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值