Lombok的@CustomLog,公司多场景日志爽多了!

开发环境

  • JDK 1.8

  • Lombok - 1.18.16

背景

公司因为开源节流需要,需要区分重要日志和非重要日志,一个月光日志的费用有30w之多确实恐怖了一些(PS:够几十个程序员的工资了)。所以,公司要求将日志区分开,去除一些非必要的日志,记录的日志也最多保留15天,重要日志30天。

为了区分场景日志,单独搞了个Logger日志记录器来采集日志,为了继续用注解的方式在项目中,这时就需要@CustomLog注解了,方便的将多个日志记录器集成在一起,话不多说,开干!

如果在项目中直接使用@CustomLog注解,你会看到如下图的报错信息:

这个时候需要添加配置文件lombok.config,在项目中就可以直接使用了!

特别注意:配置文件的位置需要在@CustomLog注解所在文件的上层目录,我为了方便通常直接放在模块的根目录或项目的根目录进行使用。

添加的配置信息如下:

lombok.log.custom.declaration=com.lombok.log.IntegrationLog com.lombok.log.IntegrationLog.getLogger(TYPE)

注意,com.lombok.log.IntegrationLog 与com.lombok.log.IntegrationLog.getLogger(TYPE)中间是有空格的,这样才能生效。至于getLogger的小括号内部,有两个值可以使用,分别是TYPE(类的类型)和NAME(类的名称)。

TYPE方式生成的代码
private static final IntegrationLog log = IntegrationLog.getLogger(LogPrintService.class);
NAME方式生成的代码
private static final IntegrationLog log = IntegrationLog.getLogger("com.lombok.service.LogPrintService");

配置成功的前提,是你的类要符合配置要求,也就是按照lombok的规范去定义类即可。

代码部分

为了方便鉴将多个日志记录器放在一起,必然需要一个集成类,这里我定义一个名为IntegrationLog的类,除了默认的Logger日志对象,还有一个业务记录器对象BusinessLog,用于记录比较重要的日志。当定义好此类后,完成上述的配置即可。

public class IntegrationLog {

    private final Logger logger;

    private final BusinessLog bizLogger;

    private IntegrationLog(Class<?> clazz) {
        this.logger = LoggerFactory.getLogger(clazz);
        this.bizLogger = BusinessLog.getLogger(clazz);
    }

    public static IntegrationLog getLogger(Class<?> clazz) {
        return new IntegrationLog(clazz);
    }

    public void info(String format, Object... args) {
        logger.info(format, args);
    }

    public void bizInfo(String format, Object... args) {
        bizLogger.info(format, args);
    }
}
再看看注解使用的代码部分

代码中我们就可以畅快的使用了,一个log对象包括了我们想要的方法。

@CustomLog
public class LogPrintService {
    public void printLog() {
        log.bizInfo("需要多付钱的日志");
        log.info("默认日志");
    }
}

通过查看源码,就可以看到Lombok给我们生成了什么样的代码:

public class LogPrintService {
    private static final IntegrationLog log = IntegrationLog.getLogger(LogPrintService.class);

    public LogPrintService() {
    }

    public void printLog() {
        log.bizInfo("哈哈哈哈", new Object[0]);
    }
}

其实Lombok做的事情,就是帮我们创建了一个实例,简单易懂。

参考文献

<think>好的,用户想知道如何在Java中使用Lombok的@Log注解进行日志记录。首先,我需要回忆Lombok的相关知识,特别是日志注解的使用方法。 Lombok提供种@Log注解,比如@Log、@Log4j、@Slf4j等,每个对应不同的日志框架。用户需要先确定他们使用的日志框架,比如Java Util Logging、Log4j、SLF4J等,然后选择对应的注解。 接下来,步骤应该是:添加Lombok依赖,导入对应的注解,然后在类上使用注解,之后直接使用log变量记录日志。需要给出具体的代码示例,比如使用@Log4j或@Slf4j的情况,并说明如何配置依赖,特别是Maven项目中的pom.xml配置。 另外,用户可能遇到的问题包括依赖未正确添加、注解不支持当前的日志框架,或者需要自定义日志名称。这时候需要提到如何通过lombok.config进行配置,或者使用@CustomLog来自定义。同时,要注意IDE是否需要安装Lombok插件,否则代码可能无法正确编译。 还需要提醒用户不同的注解对应不同的日志库,例如@Log4j需要Log4j的库,而@Slf4j需要SLF4J的实现。如果用户使用了错误的注解,可能会导致NoClassDefFoundError,这时候需要检查依赖是否正确。 最后,生成相关问题,帮助用户进一步了解,比如不同日志注解的区别、配置自定义日志名称的方法,或者解决常见问题如依赖缺失等。</think>在Java中使用Lombok的@Log系列注解可以简化日志组件的声明,具体步骤如下: 1. **添加Lombok依赖** 在Maven项目中需添加以下依赖(版本号根据需求调整): ```xml <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.30</version> <scope>provided</scope> </dependency> ```[^3] 2. **选择对应的日志注解** Lombok提供日志注解适配不同框架: ```java @Log // Java Util Logging(JDK原生) public class ClassA {} @Log4j // Apache Log4j 1.x public class ClassB {} @Slf4j // SLF4J(需具体实现如Logback) public class ClassC {} ``` 3. **直接使用log变量** 注解会自动生成名为`log`的静态日志对象: ```java @Slf4j public class PaymentService { public void process() { log.debug("Payment processing started"); log.info("Payment completed: {}", transactionId); } } ``` **特殊配置示例**: - 自定义日志名称:使用`topic`属性 ```java @Slf4j(topic = "NETWORK_LOGGER") public class NetworkClient { void connect() { NETWORK_LOGGER.info("Establishing connection"); } } ``` - 兼容新版本日志框架:对于Log4j 2.x可使用: ```java @CustomLog(topic = "security") public class AuthService { void authenticate() { security.info("Authentication attempt detected"); } } ``` **注意要点**: 1. 需确保目标日志框架的依赖已正确添加 2. 在IDE中需要安装Lombok插件以避免编译错误 3. 日志级别控制仍需通过日志框架配置文件实现
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

搞IT的成龙同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值