SpringBoot中@Scheduled定时任务重复执行、输出两次日志的问题

1、现象

在这里插入图片描述
调试定时任务时,发现控制台中出现了重复的日志信息。

2、原因分析

于是,各种的查找原因。有人说,Bean被重复创建了,什么修改Spring,Tomcat配置、注解…,按照这个思路,仔细看了一下,不只是定时任务,几乎所有的日志信息,在控制台都输出了两次。似乎真的是Bean被重复创建了…
在这里插入图片描述

按照Bean被重复创建的路子,各种修改,但是,这些统统没有用。我打的是jar包,有些地方还修改不了。一头雾水…
突然想到了,我还有日志文件,去里面看看那里的情况…
在这里插入图片描述
控制台有重复的信息,但日志文件中却是正常的。可以确定任务并没有被重复执行,Bean也没有被重复创建,只是控制台中日志信息被重复输出了。
问题大概就是在日志的配置方面出了问题。

3、解决问题

原因就是日志的配置出了问题

好的,下面是一个使用 `@Scheduled` 注解实现定时任务Spring Boot 示例代码: 首先,在 Spring Boot 项目的 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> ``` 然后,在一个 Spring BootJava 类中添加以下代码: ```java import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component public class ScheduledTasks { @Scheduled(fixedRate = 5000) // 每隔 5 秒执行一次 public void task1() { System.out.println("Task1: " + System.currentTimeMillis()); } @Scheduled(cron = "0 0/1 * * * ?") // 每分钟执行一次 public void task2() { System.out.println("Task2: " + System.currentTimeMillis()); } } ``` 上面代码中,我们使用 `@Scheduled` 注解来实现两个定时任务,一个是每隔 5 秒执行一次,另一个是每分钟执行一次。 其中,`@Scheduled` 注解有两个常用的属性: - `fixedRate`:表示任务执行的间隔时间,单位为毫秒。 - `cron`:表示基于 Cron 表达式的定时任务配置,格式为 `second minute hour dayOfMonth month dayOfWeek year`。 最后,启动 Spring Boot 应用程序,即可看到定时任务在后台自动执行输出结果。 注意:在 Spring Boot 应用程序中使用 `@Scheduled` 注解时,需要在应用程序主类上添加 `@EnableScheduling` 注解,以启用定时任务功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

土味儿~

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

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

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

打赏作者

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

抵扣说明:

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

余额充值