本人近年都在做Android项目,最近有个纯Java项目紧张,临时介入其中。日志模块,控制端显示不同等级日志同时保存到文件中,要求每天保存一个日志文件,日志目录保留最近30天日志文件。最初没想到用库,自己采用线程池方式写日志,在写日志时先判断是否有30天前的日志删除,然后对比时间判定是否有当天日志文件,之后采用BufferedWriter写日志。写好后,客户进行代码审查,不太相信我写的效率,要求采用公共控件的方式来写日志。无奈就找到了Log4j2。
以上,无聊记录一下,本文中不会涉及太基本的配置与字段的意义,部分会较详细说明一下。
1.官网下载Log4j包;
2.将其中的log4j-api-2.5.jar,log4j-core-2.5.jar加入工程;
3.src目录下加入log4j2.xml,配置好相关属性;
4.需用的代码中加入static Logger sLogger = LogManager.getLogger(LogManage.class.getName()); sLogger.debug(strLog);即可调用使用。
现就log4j2.xml注释说明:
<?xml version="1.0" encoding="UTF-8"?> <Configuration> <Appenders> <!-- 输出到控制台 --> <Console name="CONSOLE" target="SYSTEM_OUT"> <!-- 输出格式 --> <