前言

在现代企业级应用开发中,日志系统扮演着至关重要的角色。无论是问题排查、性能监控,还是业务分析,都离不开完善的日志记录。今天,我们将从零开始,手把手教你构建一个现代化的注解驱动日志框架。

为什么需要自定义日志框架?

现有日志框架的局限性

虽然市面上已有SLF4J、Logback、Log4j2等成熟的日志框架,但它们主要解决的是日志输出的问题,而在实际开发中,我们经常面临以下挑战:

// 传统日志记录方式的痛点
public class UserService {private static final Logger logger = LoggerFactory.getLogger(UserService.class);public User getUserById(Long id) {logger.info("开始查询用户,参数:{}", id);try {User user = userRepository.findById(id);logger.info("查询用户成功,结果:{}", user);return user;} catch (Exception e) {logger.error("查询用户失败,参数:{},异常:{}", id, e.getMessage(), e);throw e;}}
}

存在的问题:

  1. 代码冗余:每个方法都需要重复编写日志代码
  2. 侵入性强:业务代码与日志代码紧密耦合
  3. 不一致:不同开发者的日志风格差异很大
  4. 难维护:修改日志格式需要改动大量代码

注解驱动的优势

我们要构建的框架采用注解驱动的方式,具有以下优势:

// 使用我们的框架后
@Service
public class UserService {@LogMethod(level = LogLevel.INFO, logArgs = true, logResult = true)public User getUserById(Long id) {return userRepository.findById(id);}
}

优势对比:

  • 零侵入:业务代码完全无感知
  • 统一规范:所有日志格式保持一致
  • 灵活配置:通过注解灵活控制日志行为
  • 易于维护:日志逻辑集中管理

技术选型和架构设计

核心技术栈

Java 17
Spring Framework
Spring AOP
AspectJ
Maven
多模块项目
注解处理器
反射API

选型理由:

  • Java 17:现代Java特性,记录类型、文本块等
  • Spring AOP:成熟的切面编程框架
  • Maven:稳定的依赖管理和多模块支持
  • 注解:声明式编程,提升开发体验

整体架构设计

我们的框架采用分层模块化设计:

基础设施层
框架层
应用层
Spring Boot
Spring AOP
SLF4J
simpleflow-log-spring-boot-starter
simpleflow-log-web
simpleflow-log-aop
simpleflow-log-core
业务应用

模块职责:

  • core模块:核心注解、配置管理、上下文传递
  • aop模块:AOP切面实现、方法拦截
  • web模块:Web环境集成、HTTP请求追踪
  • starter模块:Spring Boot自动配置

项目搭建实战

1. 创建多模块Maven项目

首先创建父项目的POM文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.simpleflow</groupId><artifactId>simpleflow-log</artifactId><version>1.0.0-SNAPSHOT</version><packaging>pom</packaging><name>SimpleFlow Log Framework</name><description>基于注解驱动的企业级日志框架</description><properties><maven.compiler.source>17</maven.compiler.source><maven.compiler.target>17</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><!-- 版本管理 --><spring.boot.version>3.2.0</spring.boot.version><spring.version>6.1.0</spring.version><slf4j.version>2.0.9</slf4j.version><junit.version>5.10.0</junit.version></properties><modules><module>simpleflow-log-core</module><module>simpleflow-log-aop</module><module>simpleflow-log-web</module><module>simpleflow-log-spring-boot-starter</module><module>simpleflow-log-samples</module></modules><dependencyManagement><dependencies><!-- Spring Boot BOM --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>${spring.boot.version}</version><type>pom</type><scope>import</scope></dependency><!-- 内部模块依赖 --><dependency><groupId>com.simpleflow</groupId><artifactId>simpleflow-log-core</artifactId><version>${project.version}</version></dependency><dependency><groupId>com.simpleflow</groupId><artifactId>simpleflow-log-aop</artifactId><version>${project.version}</version></dependency></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.11.0</version><configuration><source>17</source><target>17</target></configuration></plugin></plugins></build>
</project>

2. 创建核心模块结构

创建 simpleflow-log-core 模块的POM:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.simpleflow</groupId><artifactId>simpleflow-log</artifactId><version>1.0.0-SNAPSHOT</version></parent><artifactId>simpleflow-log-core</artifactId><name>SimpleFlow Log Core</name><description>日志框架核心模块</description><dependencies><!-- 日志API --><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId></dependency><!-- JSON处理 --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId></dependency><!-- Spring Expression Language --><dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId></dependency><!-- 测试依赖 --><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><scope>test</scope></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><scope>test</scope></dependency></dependencies>
</project>

3. 第一个Hello World示例

让我们创建一个简单的示例来验证项目搭建:

// 在 core 模块中创建基础注解
package com.simpleflow.log.annotation;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;/*** 日志方法注解 - Hello World版本*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LogMethod {/*** 日志消息模板*/String value() default "";
}

创建一个简单的测试用例:

package com.simpleflow.log.annotation;import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import java.lang.reflect.Method;class LogMethodTest {private static final Logger logger = LoggerFactory.getLogger(LogMethodTest.class);@Testvoid testAnnotationPresent() throws Exception {// 获取测试方法Method method = TestService.class.getMethod("sayHello", String.class);// 检查注解是否存在if (method.isAnnotationPresent(LogMethod.class)) {LogMethod logMethod = method.getAnnotation(LogMethod.class);logger.info("发现日志注解,消息模板:{}", logMethod.value());}}// 测试用的服务类static class TestService {@LogMethod("Hello World - 参数:{}")public String sayHello(String name) {return "Hello, " + name + "!";}}
}

运行和验证

1. 编译项目

# 在项目根目录执行
mvn clean compile

2. 运行测试

mvn test

如果看到类似如下输出,说明项目搭建成功:

[INFO] 发现日志注解,消息模板:Hello World - 参数:{}
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0

本章小结

通过本章的学习,我们完成了以下工作:

✅ 完成的任务

  1. 理解需求:分析了现有日志框架的局限性
  2. 技术选型:确定了Java 17 + Spring + Maven的技术栈
  3. 架构设计:设计了分层模块化的项目结构
  4. 项目搭建:创建了多模块Maven项目
  5. 验证环境:编写并运行了第一个测试用例

🎯 学习要点

  • 注解驱动相比传统方式的优势
  • 多模块项目的组织方式和依赖管理
  • Maven依赖管理的最佳实践
  • 分层架构的设计思路

💡 思考题

  1. 为什么选择注解而不是配置文件的方式?
  2. 多模块项目相比单模块有什么优势?
  3. 如何设计一个易于扩展的框架架构?

🚀 下章预告

下一章我们将深入注解的设计,学习如何创建功能强大、易于使用的API接口。我们将设计@LogMethod@LogClass@LogIgnore三个核心注解,并探讨注解属性的最佳实践。


项目地址:https://github.com/nemoob/atlas-log

💡 小贴士: 建议读者跟着教程一步步实践,只有动手写代码才能真正掌握框架设计的精髓。遇到问题欢迎在评论区讨论!

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

173-基于Flask的微博舆情数据分析系统

基于Flask的微博舆情数据分析系统 - 技术实现与架构设计 本文详细介绍了一个基于Flask框架开发的微博舆情数据分析系统&#xff0c;包含数据爬取、情感分析、可视化展示等完整功能模块。 &#x1f4cb; 目录 项目概述技术栈系统架构目录结构核心功能模块代码实现数据可视化部署…

美股期权历史市场数据波动特性分析

标题&#xff1a;基于本地CSV数据的美股期权分析与应用实践 在金融量化研究领域&#xff0c;本地CSV数据的高效应用是开展美股期权研究的重要基础。本文将围绕美股期权日级别行情数据、波动率分析及策略构建的核心流程&#xff0c;详细介绍从数据预处理到实际场景落地的关键方…

VUE从入门到精通二:ref、reactive、computed计算属性、watch监听、组件之间的通信

目录 一、ref、reactive创建响应式对象 1、ref() 2、reactive() 3、ref和reactive的区别 二、computed计算属性 1、什么是计算属性computed 2、计算属性computed和函数方法的区别 3、计算属性computed的优势 三、watch监听函数 1、什么是watch&#xff1f; 2、基本语…

构建AI智能体:十二、给词语绘制地图:Embedding如何构建机器的认知空间

我们理解“苹果”这个词&#xff0c;能联想到一种水果、一个公司、或者牛顿的故事。但对计算机而言&#xff0c;“苹果”最初只是一个冰冷的符号或一串二进制代码。传统的“One-Hot”编码方式&#xff08;如“苹果”是[1,0,0,...]&#xff0c;“香蕉”是是[0,1,0,...]&#xff…

突击复习清单(高频核心考点)

&#x1f512; 锁的作用与使用&#xff08;synchronized vs ReentrantLock&#xff09; 面试官为什么问&#xff1a;考察你对并发编程基础的掌握程度。 速记答案&#xff1a; 作用&#xff1a;保证线程安全&#xff0c;解决多线程环境下对共享资源访问的数据不一致问题。 synch…

2025年视频大模型汇总、各自优势及视频大模型竞争焦点

文章目录一、国际主流视频大模型1. OpenAI Sora Turbo2. Google Veo 33. Runway Gen-3 Alpha二、国内主流视频大模型1. 快手可灵AI2. 爱诗科技PixVerse V33. 阿里巴巴通义万相2.14. 生数科技Vidu Q15. 字节跳动即梦AI三、核心趋势与竞争焦点一、国际主流视频大模型 1. OpenAI …

Android - 用Scrcpy 将手机投屏到Windows电脑上

工作生活当中&#xff0c;常常需要操作手机&#xff0c;但是用手操作显然不如用键盘快。 再一个&#xff0c;你看视频的时候&#xff0c;想做一些笔记&#xff0c;那你也得截个图啦之类的&#xff0c; 那如果直接在电脑上能看也是非常方便的&#xff0c;这都需要投屏手机到电…

AlmaLinux 上 Python 3.6 切换到 Python 3.11

在 AlmaLinux 上将默认的 Python 3.6 升级或切换到 Python 3.11 是一个常见的需求。请注意&#xff0c;直接替换系统自带的 Python 3.6 是非常危险的&#xff0c;因为许多系统工具&#xff08;如 yum/dnf 包管理器&#xff09;都依赖于它&#xff0c;盲目删除或修改可能会导致系…

基于RBF-GA的铝/镁异材FSLW工艺参数优化研究

课题&#xff1a;基于RBF-GA的铝/镁异材FSLW工艺参数优化研究 1. 引言 (Introduction) 研究背景与意义&#xff1a; 轻量化需求&#xff1a;铝&#xff08;Al&#xff09;和镁&#xff08;Mg&#xff09;合金是航空航天、新能源汽车等领域实现轻量化的关键材料。实现二者的可靠…

【Prometheus】Prometheus监控Docker实战

&#x1f47b;创作者&#xff1a;丶重明 &#x1f47b;创作时间&#xff1a;2025年8月23日 &#x1f47b;擅长领域&#xff1a;运维 目录前言什么是Prometheus和cAdvisorPrometheuscAdvisor部署操作部署cAdvisor部署Prometheus指标说明cpu相关指标内存相关指标磁盘相关指标网络…

2.7 提示词调优编码实战(二)

目录 四,提示词模版优化 - 格式化 4.1 代码示例 4.2 任务描述 4.3 模型输出格式化 4.4 用户输入 4.5 输出结果 四,提示词模版优化 - 格式化 在简单提示词的基础上,我们对提示词模版中各部分进行格式化。包括任务描述增加了相应的字段。 同时对输出增加了更多的定义和…

Kafka如何保证「消息不丢失」,「顺序传输」,「不重复消费」,以及为什么会发生重平衡(reblanace)

前言 上一篇文章总结了kafka为什么快&#xff0c;下面来总结一下&#xff0c;kafka高频的常见的问题。内容有点多&#xff0c;全部看完需要有一定的耐心。 kafka如何保证消息不丢失 Producer端 要保证消息不丢失&#xff0c;第一点要做的就是要保证消息从producer端发送到了…

原子操作汇编实现:原理、流程与代码解析

&#x1f52c; 原子操作汇编实现&#xff1a;原理、流程与代码解析 引用&#xff1a;VC/C Intel x86 内联汇编实现 “Interlocked” 原子变量各种操作 &#x1f31f; 引言&#xff1a;原子操作的重要性 在多线程编程中&#xff0c;原子操作是确保数据一致性的关键机制。本文…

【WRF理论第十九期】内陆湖泊、水体的处理方式

目录 WRF 模型中湖泊模拟概述 湖泊模型(Lake Model)集成 新增湖泊数据支持(如 WUDAPT + MODIS) LAKE_DEPTH Noah-MP + 湖泊模型联合使用 namelist.input 配置说明 WRF 代码更新 参考 论坛-WRF 湖泊模型(WRF-Lake model)与 SST 更新 WRF 模型中湖泊模拟概述 湖泊模型(La…

【渗透测试】SQLmap实战:一键获取MySQL数据库权限

注&#xff1a;所有技术仅用于合法安全测试与防御研究&#xff0c;未经授权的攻击行为属违法犯罪&#xff0c;将承担法律责任。一、SQLmap常规用法注意存放路径&#xff1a;C:\Users\neo\AppData\Local\sqlmap\output1、列出详细过程和数据库列表sqlmap -u http://192.168.61.2…

LeetCode 第464场周赛 第三天

1. 3658 奇数和与偶数和的最大公约数&#xff08;欧几里得&#xff09; 链接&#xff1a;题目链接 题解&#xff1a; 题解时间复杂度O(logmin(a, b))&#xff1a; 获得前n个奇、偶数的总和&#xff0c;由于数列为等差数列&#xff0c;等差数列和公式&#xff1a;(a1 an) * n …

IntelliJ IDEA 集成 ApiFox 操作与注解规范指南

一、IDEA装入Apifox 1.安装Apifox Helper 说明:在 IntelliJ IDEA 中安装 ApiFox Helper 插件。 2.打开Apifox 说明:点击 设置,在菜单中选择 API访问令牌。在弹出的窗口中输入任意名称,并选择令牌的有效期(为了方便,我这里选择了 无期限)。生成令牌后,由于 令牌只能复…

C++---双指针

在C编程中&#xff0c;双指针算法是一种高效的解题思路&#xff0c;其核心是通过设置两个指针&#xff08;或索引&#xff09;遍历数据结构&#xff08;如数组、链表、字符串等&#xff09;&#xff0c;利用指针的移动规则减少无效操作&#xff0c;从而将时间复杂度从暴力解法的…

【LLM】GLM-4.5模型架构和原理

note 文章目录note一、GLM-4.5模型二、Slime RL强化学习训练架构Reference一、GLM-4.5模型 大模型进展&#xff0c;GLM-4.5技术报告,https://arxiv.org/pdf/2508.06471&#xff0c;https://github.com/zai-org/GLM-4.5&#xff0c;包括GLM-4.5&#xff08;355B总参数&#xff…