Java日志系统之JUL

news2024/11/16 6:00:39

目录

JUL介绍

JUL的使用

日志级别

指定日志输出地址

Logger对象的父子关系

Logger读取配置文件


JUL介绍

Java自带的框架,使用简单,无需引入依赖

JUL的使用

public class JULTest {
    @Test
    public void testLogger() throws Exception{
        //获取日志记录器                   日志记录器唯一标识,一般用类名表示
        Logger logger = Logger.getLogger("com.zmt.test.JULTest");
        //日志记录输出
        logger.info("打印info日志");

        //通用方法进行输出
        logger.log(Level.INFO,"log方法打印info信息");

        String username = "zhangsan";
        String password = "123";
        logger.log(Level.INFO,"用户名:{0}密码:{1}  进行登录",new Object[]{username,password});
    }

}

十月 19, 2023 8:42:37 下午 com.zmt.test.JULTest testLogger

信息: 打印info日志

十月 19, 2023 8:42:37 下午 com.zmt.test.JULTest testLogger

信息: log方法打印info信息

十月 19, 2023 8:42:37 下午 com.zmt.test.JULTest testLogger

信息: 用户名:zhangsan密码:123 进行登录

日志级别

  • SEVERE:最高级别日志,发送严重错误
  • WARNING:次高,不会造成程序的终止但也需要处理
  • INFO:消息记录,通常记录数据库连接、网络通信等信息
  • CONFIG:配置信息,读取了配置文件参数,可以使用该级别的日志输出
  • FINE:debug时使用,打印的信息最少
  • FINER:debug时使用,打印信息较多
  • FINEST:debug时使用,打印信息最多
  • ALL:日志的开关,可以设置哪些日志级别输出(默认将所有级别都打开)
  • OFF:日志开关,默认所有级别都不输出

指定日志输出地址

    /**
     * 控制日志输出地址
     */
    @Test
    public void testLoggerPrint() throws IOException {
        //关闭默认配置
        logger.setUseParentHandlers(false);
        //输出到控制台
        ConsoleHandler consoleHandler = new ConsoleHandler();
        //格式转换对象
        SimpleFormatter simpleFormatter = new SimpleFormatter();
        //关联对象
        consoleHandler.setFormatter(simpleFormatter);
        logger.addHandler(consoleHandler);

        logger.info("输出到控制台");

        //输出到文件  指定文件保存位置,前提是文件夹存在,不存在会报错。
        //目前是D盘下的/logs,第二个参数指追加到文件后面
        FileHandler fileHandler = new FileHandler("/logs/jul.log",true);
        fileHandler.setFormatter(simpleFormatter);
        logger.addHandler(fileHandler);

        logger.info("输出到文件");
    }

运行结果为 

十月 19, 2023 9:36:41 下午 com.zmt.test.JULTest testLoggerPrint

信息: 输出到控制台

十月 19, 2023 9:36:41 下午 com.zmt.test.JULTest testLoggerPrint

信息: 输出到文件

Logger对象的父子关系

首先我们要明确我们在类中定义了一个logger成员变量

    /**
     * Logger的父子关系
     */
    @Test
    public void testLoggerParent() {
        Logger loggerParent = Logger.getLogger("com");
        System.out.println(logger.getParent() == loggerParent);
        String parentName = logger.getParent().getName();
        System.out.println(parentName);
        Logger grantParent = loggerParent.getParent();
        String grantParentName = grantParent.getName();
        System.out.println(grantParent+"名称为:"+grantParentName);
    }

运行结果为 

true

com

java.util.logging.LogManager$RootLogger@e73f9ac名称为:

成员变量的logger对象父类对象是名称为com的logger对象。没有指定父类的logger对象默认是LogManager中的RootLogger。

Logger读取配置文件

我们手动设置logger的输出级别或是handler的关联不利于我们代码修改与读取,JUL支持配置文件的读取。观察获取Logger对象的方法getLogger()源码。

去读取Jar包中的默认的配置文件。打上断点debug查看对应的文件目录。

打开文件查看

这就是默认的配置文件,默认的logger对象只会打印在控制台上。默认打印级别为INFO。默认使用的格式转换是SImpleFormatter。

文件处理器的配置中%h意思是当前用户目录文件名以java开头,log结尾。%u作用是以数字取值。默认一个文件中存储50000条信息,只会创建从0到1两个文件,使用XMLFormatter文件转换。

读取完配置文件后,创建根Logger对象。

接下来我们测试一下自定义配置文件。在resource目录下配置如下文件

    /**
     * 测试Logger读取配置文件
     */
    @Test
    public void testLoggerConfig() throws IOException {
        InputStream in = JULTest.class.getClassLoader().getResourceAsStream("logging.properties");
        LogManager logManager = LogManager.getLogManager();
        logManager.readConfiguration(in);
        Logger logger = Logger.getLogger("com.zmt.test");
        logger.info("测试配置文件");
    }

运行结果

配置文件大体能用到的解释

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1116317.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2 用TensorFlow构建一个简单的神经网络

上一篇:1 如何入门TensorFlow-CSDN博客 环境搭建 后续介绍的相关代码都是在pycharm运行,pycharm安装略。 打开pycharm,创建一个新的项目用于tensorflow编码练习,在Terminal输入命令: # 依赖最新版本的pip pip inst…

[AutoSAR系列] 1.2 AutoSar 综述

AutoSAR是一种汽车工业领域的标准化软件架构,旨在简化不同汽车制造商之间的软件开发和交互。该标准于2003年由一系列欧洲汽车制造商成立的AutoSAR联盟制定并发布,目前已经成为全球范围内的标准。下面将对AutoSAR的概念、架构和实现进行综述。 1. 概述 AutoSAR是汽车电子控制…

Qt 读写文件(QFileQTextStreamQDataStream) 详解

一、读写文本文件 (QFile 类) Qt QFile类是一个用于读取和写入文件的类,它提供了对文件的访问、读取和写入等操作。它既可以操作文本文件,也可以操作二进制文件。 QFile类的功能包括: 打开、关闭文件读取文件内容写入文件内容支持文本模式…

如何让ChatGPT生成图片?

目录 一、那么如何解决让ChatGPT具有画图能力的问题呢? 二、那ChatGPT为什么能生成图片呢? 我们都知道ChatGPT只是个纯文本的AI模型,不具备画图能力。它可以生成文本,但如果让他生成图片就会显示如下的声明: 但通过本…

前端多媒体处理工具——ffmpeg的使用

写在前面 在前端领域,FFmpeg 是一个非常有用的工具,它提供了多种媒体格式的封装和解封装,包括多种音视频编码、多种协议的流媒体、多种色彩格式转换、多种采样率转换、多种码率切换等。可以在多种操作系统安装使用。 安装 下载FFmpeg 在网…

服务器数据恢复-某银行服务器硬盘数据恢复案例

服务器故障&分析: 某银行的某一业务模块崩溃,无法正常使用。排查服务器故障,发现运行该业务模块的服务器中多块硬盘离线,导致上层应用崩溃。 故障服务器内多块硬盘掉线,硬盘掉线数量超过服务器raid阵列冗余级别所允…

文件目录(文件控制块FCB,目录结构,索引结点)

1.文件控制块(实现文件目录的关键数据结构) 目录文件中的一条记录就是文件控制块(FCB) FCB的有序集合称为“文件目录”,一个FCB就是一个文件目录项。 1.FCB的组成 FCB中包含了文件的基本信息(文件名、物理地址、逻…

墨迹天气商业版UTF-8模板,Discuz3.4灰白色风格(带教程)

1.版本支持:Discuzx3.4版本,Discuzx3.3版本,DiscuzX3.2版本。包括网站首页,论坛首页,论坛列表页,论坛内容页,论坛瀑布流,资讯列表页(支持多个),产品列表页(支持多个),关于…

【TES600】青翼科技基于XC7K325T与TMS320C6678的通用信号处理平台

板卡概述 TES600是一款基于FPGA+DSP协同处理架构的通用高性能实时信号处理平台,该平台采用1片TI的KeyStone系列多核浮点/定点DSP TMS320C6678作为主处理单元,采用1片Xilinx的Kintex-7系列FPGA XC7K325T作为协处理单元,具有1个FMC…

Android Studio(2022.3.1)设置阿里云源-新旧版本

新版本 #settings.gradle.ktsmaven { url uri("https://maven.aliyun.com/repository/public/") }maven { url uri("https://maven.aliyun.com/repository/google/") }maven { url uri("https://maven.aliyun.com/repository/jcenter/") }ma…

VBA操作数据库

相关背景: 对于数据分析同学,一般SQL,EXCEL是必备技能,但对于VBA和Python可能有的同学不会;在处理本地数据上(诸如excel、txt|csv文本),后续尝试使用VBA或者Python写一个sql查询的GUI界面&…

dubbogo-1 基础rpc服务

文章目录 基本环境处理编译pb接口开启rpc调用业务观察qa1 能取出protoc里面的字段值吗? 基本环境处理 https://cn.dubbo.apache.org/zh-cn/overview/quickstart/go/install/ 这里没有 protoc-gen-go --version 执行 go get -u github.com/golang/protobuf/protoc…

嵌入式养成计划-45----QT--事件机制--定时器事件--键盘事件和鼠标事件--绘制事件

一百一十五、事件机制 当这件事情发生时,会自动走对应的函数处理(重写的事件函数) 115.1 事件处理简介 什么是事件? (重点) 件是由窗口系统或者自身产生的,用以响应所发生的各类事情,比如用户按下并释放…

vscode调试技巧 断言 assert

目录 调试技巧标题debug release介绍调试技巧断点 断点的意思 就是代码执行到断点处停下来,让你去调试。不管前面有多少代码,直接跳到断点处(当然前面的已经执行)逐过程 不会进入调用函数内部,不管里面怎么执行。 逐语…

精讲stable diffusion的controlNet插件

controlNet插件是stable diffusion的一个重要插件,甚至可以说正是因为有了controlNet插件,stable diffusion才会具有midjourney所不具备的独特魅力! 我们今天就一起来学习下controlNet插件的安装和每个模型的用法 插件主页 独立的controlN…

MSP430F5529时钟系统配置

1、为什么要进行时钟管理?   时钟系统是一个数字器件的命脉,对于普通的51单片机来说,它的时钟来源只有外部晶振,然后每12个振荡周期完成一个基本操作,所以也叫做12T单片机,但对于当前高级一点的单片机来…

牛客:NC59 矩阵的最小路径和

牛客:NC59 矩阵的最小路径和 文章目录 牛客:NC59 矩阵的最小路径和题目描述题解思路题解代码 题目描述 题解思路 动态规划,递推公式:matrix[i][j] min(matrix[i-1][j], matrix[i][j-1]) 题解代码 func minPathSum( matrix [][…

性能压测工具 —— wrk

一般我们压测的时候,需要了解衡量系统性能的一些参数指标,比如。 1、性能指标简介 1.1 延迟 简单易懂。green:一般指响应时间 95线:P95。平均100%的请求中95%已经响应的时间 99线:P99。平均100%的请求中99%已经响应的时间 平…

maven聚合和继承

一、什么是maven的聚合和继承&why 随着技术飞速发展,各类用户对软件的要求越来越高,软件也变得越来越复杂。 软件设计人员往往会采用各种方式对软件划分模块,已得到更加清晰的设计及更高的复用性。 当把Maven应用到实际项目中的时候&am…

多年没有遇到如此流畅的面试了

美东一公司的面试,有多年没有遇到如此流畅的面试了。 本来说的面试时间是 30 分钟,这个还是第一轮处于电话面试那种,但是不知道为什么最后面试整个时间都延长到了快一个小时,貌似双方都还继续沟通下,有点意犹未尽的感觉…