目录
日志级别
记录器Logger
如何生成记录器:
每个记录器Logger的属性
name属性:
level属性(可选):
additivity属性(可选):
说明:
附加器Appender
常用的附加器
Pattern标签
控制台附加器:ch.qos.logback.core.ConsoleAppender
文件附加器: ch.qos.logback.core.FileAppender
滚动文件附加器:ch.qos.logback.core.rolling.RollingFileAppender
过滤器
常用过滤器
记录器可加性additivity
SpringBoot中使用logback
根据阿里云开发规范,日志的记录最好分成error, debug,info. 分开记录。按天生成。这样就比较方便问题定位查找。下面附上配置
${APP_NAME}
%black(%contextName - %d{yyyy-MM-dd HH:mm:ss}) %green([%c][%t][%L]) %highlight(%-5level) - %gray(%msg%n)
${LOG_HOME}/debug-%d{yyyy-MM-dd}.log
${LOG_MAX_HISTORY}
%d{yyyy-MM-dd HH:mm:ss.SSS} [%c][%t][%L][%p] - %msg%n
UTF-8
debug
ACCEPT
DENY
${LOG_HOME}/info-%d{yyyy-MM-dd}.log
${LOG_MAX_HISTORY}
%d{yyyy-MM-dd HH:mm:ss.SSS} [%c][%t][%L][%p] - %msg%n
UTF-8
info
ACCEPT
DENY
${LOG_HOME}/error-%d{yyyy-MM-dd}.log
${LOG_MAX_HISTORY}
%d{yyyy-MM-dd HH:mm:ss.SSS} [%c][%t][%L][%p] - %msg%n
UTF-8
error
ACCEPT
DENY
java日志共分为五个级别
等级排序为: TRACE < DEBUG < INFO < WARN < ERROR
日志记录器: 控制要输出哪些日志记录语句,对日志信息进行级别限制,
final static Logger logger = LoggerFactory.getLogger("名称");
记录器的名称
记录器的级别,允许的级别从低到高TRACE < DEBUG < INFO < WARN < ERROR
logger.setLevel()
logger.getLevel();
logger.getEffectiveLevel()
是否允许叠加打印日志,true或false
ch.qos.logback.classic.Logger logger =
(ch.qos.logback.classic.Logger) LoggerFactory.getLogger(App.class);
记录器会将输出日志的任务交给附加器完成,不同的附加器会将日志输出到不同的地方,比如控制台附加器、文件附加器、网络附加器等等。
- 控制台附加器: ch.qos.logback.core.ConsoleAppender
- 文件附加器: ch.qos.logback.core.FileAppender
- 滚动文件附加器: ch.qos.logback.core.rolling.RollingFileAppender
pattern由文字文本(abcd……)和转换说明符(%date %msg ……)的格式控制表达式组成,可以向其中自由插入任何文字文本。每个转换说明符都以百分号‘%’后跟可选的 格式修饰符、转换字和大括号之间的可选参数。转换字控制要转换的数据字段,例如记录器的名称、级别、日期和线程名称。格式修饰符控制字段长度、填充以及左对齐或右对齐。
文件附加器的缺点:
我们知道我们打印的所有的日志信息都会存储到logs的文件中,该动作并不会考虑该文件的容量和大小,只要有,就往里塞。就会导致日志文件臃肿和日志信息查询繁琐的问题。
所以推荐使用滚动文件附加器: ch.qos.logback.core.rolling.RollingFileAppender
滚动策略
ch.qos.logback.core.rolling.TimeBasedRollingPolicy
ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy
值得注意的是:
在时间空间策略中,
例如:我在2月28日看我的日志文件,那么日志文件只保留26、27、28这三天的日志信息。
LevelFilter(级别过滤器):实现类 ch.qos.logback.classic.filter.LevelFilter
ThresholdFilter(阈值过滤器):实现类 ch.qos.logback.classic.filter.ThresholdFilter
EvaluatorFilter(评估者过滤器):实现类 ch.qos.logback.classic.filter.EvaluatorFilter
JaninoEventEvaluator过滤器:实现类 ch.qos.logback.classic.filter.EvaluatorFilter
TurboFilter涡轮过滤器
DuplicateMessageFilter 重复消息过滤器
如图所示:我定义了两个记录器,root是根记录器,c.karami是子记录器。当两个记录器用同一个附加器时,就会打印两条相同的个日志文件。如图:
如果我们不想让控制台输出相同的日志信息,只需要在记录器中添加一个属性 additivity = "false"即可。如图
在sp中使用logback没有什么要注意的点,如果你想要将logback.xml文件重新命名为其他的名字,只需要在application.yml去配置一下该文件的目录。