log日志最佳实践

news2025/5/27 14:56:32

log日志最佳实践

  • 1、占位符的使用
  • 2、延迟计算

1、占位符的使用

在进行日志打印的时候,推荐使用占位符进行字符串打印,而不是直接使用字符串拼接。原因:

  • 这样可以避免不必要的字符串拼接。使用占位符时,实际字符串拼接由日志框架在确定真正需要输出日之后才执行。例如,如果日志输出的是debug(),但是配置的是info级别,则不会执行字符串拼接
  • 减少临时对象创建。字符串拼接会产生多个临时String对象,而占位符方式通常由日志框架优化为更高效的内存处理方式
  • 更清晰的日志模版。日志输出模版和变量分离

接下来代码显示。定义实体类:

@Setter
@Getter
public class User {

    public Integer age;
    private String name;
    public boolean gender;

    @Override
    public String toString() {
    	// 延迟10秒,为了查看延迟计算
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
        StringBuilder sb = new StringBuilder();
        sb.append("{");
        sb.append("name:").append(name).append(",");
        sb.append("age:").append(age).append(",");
        sb.append("gender:").append(gender);
        sb.append("}");
        return sb.toString();
    }
}
@Slf4j
public class Test {
    public static void main(String[] args) {
        User user = new User();
        user.setAge(15);
        user.setName("Jack");
        user.setGender(true);
        // 方式一:直接字符串拼接
        log.trace("output1:" + JSONUtil.toString(user));
        // 方式二:使用占位符进行输出。相比于第一种方式,更推荐这种进行日志打印
        log.trace("output2:{}", JSONUtil.toString(user));
	}
}

2、延迟计算

延迟计算就是只有真正进行日志打印的时候才会计算打印的内容。尤其是日志打印的内容特别的大或者是计算打印的日志内容特别的耗时。

模拟JSON序列化类:

@Setter
public class JSONUtil {
	// 目标对象
    Object o;
	// 对目标对象简单序列化
    @Override
    public String toString() {
        return JSON.toJSONString(o);
    }
    
	// 对对象简单序列化
    public static String toString(Object o) {
        return o.toString();
    }
}

测试延迟计算:

@Slf4j
public class Test {

    public static void main(String[] args) {
        User user = new User();
        user.setAge(15);
        user.setName("Jack");
        user.setGender(true);
        
        long start = System.currentTimeMillis();
        log.trace("output1:" + JSONUtil.toString(user));
        long end = System.currentTimeMillis();
        System.out.println("字符串拼接用时: " + (end - start) / 1000);

        start = System.currentTimeMillis();
        log.trace("output2:{}", JSONUtil.toString(user));
        end = System.currentTimeMillis();
        System.out.println("占位符加序列化用时: " + (end - start) / 1000);

        start = System.currentTimeMillis();
        log.trace("output3:{}", user);
        end = System.currentTimeMillis();
        System.out.println("占位符加自身toString用时: " + (end - start) / 1000);

        start = System.currentTimeMillis();
        JSONUtil jsonUtil1 = new JSONUtil();
        jsonUtil1.setO(user);
        log.trace("output4:{}", jsonUtil1);
        end = System.currentTimeMillis();
        System.out.println("占位符加自身toString调用JSON序列化用时: " + (end - start) / 1000);

    }
}

结果输出:

字符串拼接用时: 10
占位符加序列化用时: 10
占位符加自身toString用时: 0
占位符加自身toString调用JSON序列化用时: 0

本文的日志级别为debug,所以这里使用的是trace()进行打印,就是为了不打印查看延迟计算效果。通过上面结果可以看出,只要字符串拼接或者是使用占位符,但是对打印对象进行操作都不会出发延迟计算,都是直接计算出结果再执行log日志打印。
延迟计算条件:

  • 使用占位符进行日志打印
  • 打印的变量不能在打印语句中执行任何方法、操作。直接输出变量

在最终确定日志打印的时候会调用打印变量的toString()方法进行字符串拼接输出。如果默认的toString()方法或者Lombok输出的toString()方法输出的不满足诉求【例如,elk需要严格的json】,要么重写,要么封装到另一个对象中,另一个对象toString()方法进行序列化,例如上述的JSONUtil。

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

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

相关文章

FreeRTOS--消息队列

一、简介 消息队列是FreeRTOS中用于任务与任务或任务与中断之间数据交换的一种机制,采用FIFO(先进先出)方式管理数据,也可以采用LIFO(后进先出)方式。有点类似全局变量。 1.1 那为什么不直接使用全局变量&a…

三步快速部署一个本地Windows/Linux大语言模型ChatGLM(环境配置+权重下载+运行)

前言: 最近刚拿到实验室一个装了3张3090显卡的服务器账号,感觉不用来霍霍有点浪费,于是有了部署一个大语言模型的想法,除去下载权重和传文件到服务器上可能也就用了十分钟不到(这下看懂为啥python受众现在这么广了&…

DeepSeek联网Google搜索引擎

目录: 1、使用背景2、实现代码3、Gradio 的 yield 机制 1、使用背景 比如所有易建联是什么时候退役的?使用大模型对这种实事回答不准确,需要通过联网搜索处理。 正确答案应该是2023年8月29日退役。 2、实现代码 # import gradio as gr# d…

奈雪小程序任务脚本

功能概述 该脚本用于自动完成奈雪点单小程序的每日任务,包括: 自动检测 Token 有效性自动签到(如果未签到)获取用户基础信息(昵称、手机号)查询当前奈雪币余额记录连续签到天数支持多账号执行&#xff0c…

上海医日健集团物联网专利技术领跑智慧药房赛道

在智慧医疗蓬勃发展的浪潮中,上海医日健集团凭借其卓越的创新能力与强大的技术实力,在智慧药房领域崭露头角。集团自主研发的物联网专利技术,正以前所未有的优势,重塑智慧药房运营模式,引领行业迈向新的发展高度。 上…

基于Java+MySQL实现(Web)图书借阅管理系统

图书借阅管理系统(前后台) 1 需求分析 图书借阅管理系统是模拟学校图书馆实现的一个具有前后台的 Web 系统.对于读者,能够提供全文检索,个性化推荐,借阅等功能.对于管理员,能够提供可视化数据分析,信息管理等功能. 2 技术栈 前端: Layui,jQuery,echarts 后端:Spring Boot,…

SAR ADC的功耗设计

SAR ADC 由比较器、逻辑和DAC组成,功耗比可能是3:6:1,对于低功耗设计来说,我们需要尽量让DAC的功耗最小,这里来探讨一下CDAC的功耗计算方法。 CDAC从状态1切换到状态2时,需要从Vref buffer上抽拉电荷。C是状态2时连接Vref的总电容,V2就是状态2时接Vref的电容上的电压…

PP-OCRv5

目录 PP-OCRv5官方效果如下 C封装、C#调用效果 项目 代码 下载 PP-OCRv5官方效果如下 C封装、C#调用效果 项目 代码 using Newtonsoft.Json; using OpenCvSharp; using System; using System.Collections.Generic; using System.Diagnostics; using System.Drawing; usi…

nginx的一些配置的意思

1.用这个端口可以访问到nginx 2.工作进程,设置成和cpu核心数一样即可 3.每个工作进程的最大网络连接数。 4.主机名称 设置反向代理时,把server_name设置成ip。 5.反向代理进行转发,localhost指的是nginx所在的机器。 关键字proxy_pass。 …

Agent模型微调

这篇文章讲解: 把 Agent 和 Fine-Tuning 的知识串起来,在更高的技术视角看大模型应用;加深对 Agent 工作原理的理解;加深对 Fine-Tuning 训练数据处理的理解。 1. 认识大模型 Agent 1.1 大模型 Agent 的应用场景 揭秘Agent核心…

Linux基本指令篇 —— whoami指令

whoami 是 Linux 和 Unix 系统中一个简单但实用的命令,全称 Who Am I(我是谁)。它的功能是显示当前登录用户的用户名。以下是关于 whoami 的详细解析: 目录 1. 基本用法 2. 命令特点 3. 实际应用场景 场景 1:脚本中…

力扣395做题笔记

题目链接 力扣395 第一次尝试 class Solution {public int longestSubstring(String str, int k) {char[] s str.toCharArray();int n s.length;int[] cnts new int[256];int ans 0;for (int r 0, l 0; r < n; r ) { cnts[s[r]];if (cnts[s[r]] > k) { ans Mat…

WebSocket(看这一篇就够了)

文章目录 WebSocket 基本概念什么是WebSocket?为什么需要 WebSocket&#xff1f;与 HTTP 协议的区别WebSocket协议的原理WebSocket工作流程WebSocket 数据帧结构和控制帧结构。JavaScript 中 WebSocket 对象的属性和方法&#xff0c;以及如何创建和连接 WebSocket。webSocket简…

旧物回收小程序:让闲置焕发光彩,为生活增添价值

你是否常常为家中堆积如山的闲置物品而烦恼&#xff1f;那些曾经心爱的物品&#xff0c;如今却成了占据空间的“鸡肋”&#xff0c;丢弃可惜&#xff0c;留着又无处安放。别担心&#xff0c;一款旧物二手回收小程序将为你解决这一难题&#xff0c;让闲置物品重新焕发光彩&#…

数学建模MathAI智能体-2025电工杯A题实战

题目&#xff1a; 光伏电站发电功率日前预测问题 光伏发电是通过半导体材料的光电效应&#xff0c;将太阳能直接转化为电能的技术。光伏电站是由众多光伏发电单元组成的规模化发电设施。 光伏电站的发电功率主要由光伏板表面接收到的太阳辐射总量决定&#xff0c;不同季节太阳…

C# Windows Forms应用程序-002

目录 项目结构 主类和命名空间 构造函数和析构函数 初始化组件 (InitializeComponent) 按钮点击事件处理程序 主程序入口点 项目截图&#xff1a; 完整代码&#xff1a; 项目结构 这个项目是一个简单的C# Windows Forms应用程序&#xff0c;获取指定文件的根信息…

理解计算机系统_线程(八):并行

前言 以<深入理解计算机系统>(以下称“本书”)内容为基础&#xff0c;对程序的整个过程进行梳理。本书内容对整个计算机系统做了系统性导引,每部分内容都是单独的一门课.学习深度根据自己需要来定 引入 接续理解计算机系统_并发编程(10)_线程(七):基于预线程化的…

【MySQL】09.索引

索引是用来提高数据库的性能的&#xff0c;但查询速度的提高是以插入、更新、删除的速度为代价的&#xff0c;这些写操作&#xff0c;增加了大量的IO。所以它的价值在于提高一个海量数据的检索速度。 1. 认识磁盘 MySQL 给用户提供存储服务&#xff0c;而存储的都是数据&…

【备忘】 windows 11安装 AdGuardHome,实现开机自启,使用 DoH

windows 11安装 AdGuardHome&#xff0c;实现开机自启&#xff0c;使用 DoH 下载 AdGuardHome解压 AdGuardHome启动 AdGuard Home设置 AdGuardHome设置开机自启安装 NSSM设置开机自启重启电脑后我们可以访问 **http://127.0.0.1/** 设置使用 AdGuardHome DNS 效果图 下载 AdGua…

[Windows] 游戏常用运行库- Game Runtime Libraries Package(6.2.25.0409)

游戏常用运行库 合集 整合了许多游戏会用到的运行库&#xff0c;支持 Windows XP – Windows 11 系统&#xff0c;并且支持自动检测系统勾选推荐的运行库&#xff0c;方便快捷。 本版特点&#xff1a; By&#xff1a;mefcl 整合常见最新游戏所需运行库 根据系统自动勾选推荐…