这是JDK为我们提供的日志框架,位于`java.util.logging`包下,通过日志输出的结果会更加规范
- public class Main {
- public static void main(String[] args) {
- // 首先获取日志打印器
- Logger logger = Logger.getLogger(Main.class.getName());
- // 调用info来输出一个普通的信息,直接填写字符串即可
- logger.info("我是普通的日志");
- }
- }
输出
十一月 15, 2021 12:55:37 下午 com.test.Main main
信息: 我是普通的日志
日志分为7个级别,详细信息我们可以在Level类中查看:
* SEVERE(最高值)- 一般用于代表严重错误
* WARNING - 一般用于表示某些警告,但是不足以判断为错误
* INFO (默认级别) - 常规消息
* CONFIG config
* FINE
* FINER
* FINEST(最低值)finest
通过`log`方法来设定该条日志的输出级别:
- public static void main(String[] args) {
- Logger logger = Logger.getLogger(Main.class.getName());
- logger.log(Level.SEVERE, "严重的错误", new IOException("我就是错误"));
- logger.log(Level.WARNING, "警告的内容");
- logger.log(Level.INFO, "普通的信息");
- logger.log(Level.CONFIG, "级别低于普通信息");
- }
级别低于默认级别的日志信息,无法输出到控制台,我们可以通过设置来修改日志的打印级别
- public static void main(String[] args) {
- Logger logger = Logger.getLogger(Main.class.getName());
-
- //修改日志级别
- logger.setLevel(Level.CONFIG);
- //不使用父日志处理器
- logger.setUseParentHandlers(false);
- //使用自定义日志处理器
- ConsoleHandler handler = new ConsoleHandler();
- handler.setLevel(Level.CONFIG);
- logger.addHandler(handler);
-
- logger.log(Level.SEVERE, "严重的错误", new IOException("我就是错误"));
- logger.log(Level.WARNING, "警告的内容");
- logger.log(Level.INFO, "普通的信息");
- logger.log(Level.CONFIG, "级别低于普通信息");
- }
每个`Logger`都有一个父日志打印器,我们可以通过`getParent()`来获取,得到的是`java.util.logging.LogManager$RootLogger`这个类,它默认使用的是ConsoleHandler,且日志级别为INFO,由于每一个日志打印器都会直接使用父类的处理器,因此我们之前需要关闭父类然后使用我们自己的处理器。
日志处理器不仅仅只有控制台打印,我们也可以使用文件处理器来处理日志信息
- //添加输出到本地文件
- FileHandler fileHandler = new FileHandler("test.log");
- fileHandler.setLevel(Level.WARNING);
- logger.addHandler(fileHandler);
如果日志的打印格式我们不喜欢,我们还可以自定义打印格式,比如我们控制台处理器就默认使用的是`SimpleFormatter`,而文件处理器则是使用的`XMLFormatter`
- //使用自定义日志处理器(控制台)
- ConsoleHandler handler = new ConsoleHandler();
- handler.setLevel(Level.CONFIG);
- handler.setFormatter(new XMLFormatter());
- logger.addHandler(handler);
日志可以设置过滤器,如果我们不希望某些日志信息被输出,我们可以配置过滤规则:
- public static void main(String[] args) throws IOException {
- Logger logger = Logger.getLogger(Main.class.getName());
-
- //自定义过滤规则
- logger.setFilter(record -> !record.getMessage().contains("普通"));
-
- logger.log(Level.SEVERE, "严重的错误", new IOException("我就是错误"));
- logger.log(Level.WARNING, "警告的内容");
- logger.log(Level.INFO, "普通的信息");
- }
打印格式还可以自行实现
- public static void main(String[] args) throws IOException {
- Logger logger = Logger.getLogger(Main.class.getName());
- logger.setUseParentHandlers(false);
-
- //为了让颜色变回普通的颜色,通过代码块在初始化时将输出流设定为System.out
- ConsoleHandler handler = new ConsoleHandler(){{
- setOutputStream(System.out);
- }};
- //创建匿名内部类实现自定义的格式
- handler.setFormatter(new Formatter() {
- @Override
- public String format(LogRecord record) {
- SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
- String time = format.format(new Date(record.getMillis())); //格式化日志时间
- String level = record.getLevel().getName(); // 获取日志级别名称
- // String level = record.getLevel().getLocalizedName(); // 获取本地化名称(语言跟随系统)
- String thread = String.format("%10s", Thread.currentThread().getName()); //线程名称(做了格式化处理,留出10格空间)
- long threadID = record.getThreadID(); //线程ID
- String className = String.format("%-20s", record.getSourceClassName()); //发送日志的类名
- String msg = record.getMessage(); //日志消息
-
- //\033[33m作为颜色代码,30~37都有对应的颜色,38是没有颜色,IDEA能显示,但是某些地方可能不支持
- return "\033[38m" + time + " \033[33m" + level + " \033[35m" + threadID
- + "\033[38m --- [" + thread + "] \033[36m" + className + "\033[38m : " + msg + "\n";
- }
- });
- logger.addHandler(handler);
-
- logger.info("我是测试消息1...");
- logger.log(Level.INFO, "我是测试消息2...");
- logger.log(Level.WARNING, "我是测试消息3...");
- }
使用Lombok快速开启日志
- @Log
- public class Main {
- public static void main(String[] args) {
- System.out.println("自动生成的Logger名称:"+log.getName());
- log.info("我是日志信息");
- }
- }
添加`@Log`注解就可以直接使用一个静态变量log,而它就是自动生成的Logger
- @Log(topic = "zzp")
- public class Main {
- public static void main(String[] args) {
- System.out.println("自动生成的Logger名称:"+log.getName());
- log.info("我是日志信息");
- }
- }