SpringBoot2.0 基础案例(04):定时任务和异步任务的使用方式
一、定时任务
1、基本概念
按照指定时间执行的程序。
2、使用场景
数据分析
数据清理
系统服务监控
二、同步和异步
1、基本概念
同步调用
程序按照代码顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行;
异步调用
顺序执行时,不等待异步调用的代码块返回结果就执行后面的程序。
2、使用场景
短信通知
邮件发送
批量数据入缓存
三、SpringBoot2.0使用定时器
1、定时器执行规则注解
@Scheduled(fixedRate = 5000) :上一次开始执行时间点之后5秒再执行
@Scheduled(fixedDelay = 5000) :上一次执行完毕时间点之后5秒再执行
@Scheduled(initialDelay=1000, fixedRate=5000) :第一次延迟1秒后执行,之后按fixedRate的规则每5秒执行一次
@Scheduled(cron="/5") :通过cron表达式定义规则
2、定义时间打印定时器
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.text.SimpleDateFormat;
import java.util.Date;
/*** 时间定时任务*/
@Component
public class TimeTask {Logger LOG = LoggerFactory.getLogger(TimeTask.class.getName()) ;private static final SimpleDateFormat format =new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") ;/*** 每3秒打印一次系统时间*/@Scheduled(fixedDelay = 3000)public void systemDate (){LOG.info("当前时间::::"+format.format(new Date()));}
}
3、启动类开启定时器注解
@EnableScheduling // 启用定时任务
@SpringBootApplication
public class TaskApplication {public static void main(String[] args) {SpringApplication.run(TaskApplication.class,args) ;}
}
四、SpringBoot2.0使用异步任务
1、编写异步任务类
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
@Component
public class AsyncTask {private static final Logger LOGGER = LoggerFactory.getLogger(AsyncTask.class) ;/** [ asyncTask1-2] com.boot.task.config.AsyncTask : ======异步任务结束1======* [ asyncTask1-1] com.boot.task.config.AsyncTask : ======异步任务结束0======*/// 只配置了一个 asyncExecutor1 不指定也会默认使用@Asyncpublic void asyncTask0 () {try{Thread.sleep(5000);}catch (Exception e){e.printStackTrace();}LOGGER.info("======异步任务结束0======");}@Async("asyncExecutor1")public void asyncTask1 () {try{Thread.sleep(5000);}catch (Exception e){e.printStackTrace();}LOGGER.info("======异步任务结束1======");}
}
2、指定异步任务执行的线程池
这里可以不指定,指定执行的线城池,可以更加方便的监控和管理异步任务的执行。
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
import java.util.concurrent.ThreadPoolExecutor;
/*** 定义异步任务执行的线程池*/
@Configuration
public class TaskPoolConfig {@Bean("asyncExecutor1")public Executor taskExecutor1 () {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();// 核心线程数10:线程池创建时候初始化的线程数executor.setCorePoolSize(10);// 最大线程数20:线程池最大的线程数,只有在缓冲队列满了之后才会申请超过核心线程数的线程executor.setMaxPoolSize(20);// 缓冲队列200:用来缓冲执行任务的队列executor.setQueueCapacity(200);// 允许线程的空闲时间60秒:当超过了核心线程出之外的线程在空闲时间到达之后会被销毁executor.setKeepAliveSeconds(60);// 线程池名的前缀:设置好了之后可以方便定位处理任务所在的线程池executor.setThreadNamePrefix("asyncTask1-");/*线程池对拒绝任务的处理策略:这里采用了CallerRunsPolicy策略,当线程池没有处理能力的时候,该策略会直接在 execute 方法的调用线程中运行被拒绝的任务;如果执行程序已关闭,则会丢弃该任务*/executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());// 设置线程池关闭的时候等待所有任务都完成再继续销毁其他的Beanexecutor.setWaitForTasksToCompleteOnShutdown(true);// 设置线程池中任务的等待时间,如果超过这个时候还没有销毁就强制销毁,以确保应用最后能够被关闭,而不是阻塞住。executor.setAwaitTerminationSeconds(600);return executor;}
}
3、启动类添加异步注解
@EnableAsync // 启用异步任务
@SpringBootApplication
public class TaskApplication {public static void main(String[] args) {SpringApplication.run(TaskApplication.class,args) ;}
}
4、异步调用的测试接口
@RestController
public class TaskController {@Resourceprivate AsyncTask asyncTask ;@RequestMapping("/asyncTask")public String asyncTask (){asyncTask.asyncTask0();asyncTask.asyncTask1();return "success" ;}
}
五、源代码地址
GitHub:知了一笑
https://github.com/cicadasmile/spring-boot-base
SpringBoot2.0 基础案例(04):定时任务和异步任务的使用方式相关推荐
- SpringBoot2.0基础案例分类总结,后续更新计划说明
一.基础案例 1.基础案例概览 历时一个半月,SpringBoot2.0基础案例的文章基本更新完毕了,基础案例包含了SpringBoot的基础教程,高级应用,日志配置,数据库使用,事务管理等.关于Sp ...
- SpringBoot2.0 基础案例(12):基于转账案例,演示事务管理操作
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.事务管理简介 1.事务基本概念 一组业务操作ABCD,要么全部 ...
- SpringBoot2.0 基础案例(14):基于Yml配置方式,实现文件上传逻辑
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.文件上传 文件上传是项目开发中一个很常用的功能,常见的如头像上 ...
- SpringBoot2.0 基础案例(13):基于Cache注解模式,管理Redis缓存
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.Cache缓存简介 从Spring3开始定义Cache和Cac ...
- SpringBoot2.0基础案例(01):环境搭建和RestFul风格接口
一.SpringBoot 框架的特点 SpringBoot2.0 特点 1)SpringBoot继承了Spring优秀的基因,上手难度小 2)简化配置,提供各种默认配置来简化项目配置 3)内嵌式容器简 ...
- SpringBoot2.0 基础案例(16):配置Actuator组件,实现系统监控
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.Actuator简介 1.监控组件作用 在生产环境中,需要实时 ...
- SpringBoot2.0 基础案例(15):配置MongoDB数据库,实现增删改查逻辑
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.NoSQL简介 1.NoSQL 概念 NoSQL( Not O ...
- SpringBoot2.0 基础案例(10):整合Mybatis框架,集成分页助手插件
一.Mybatis框架 1.mybatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获 ...
- SpringBoot2.0 基础案例(09):集成JPA持久层框架,简化数据库操作
一.JAP框架简介 JPA(Java Persistence API)意即Java持久化API,是Sun官方在JDK5.0后提出的Java持久化规范.主要是为了简化持久层开发以及整合ORM技术,结束H ...
最新文章
- 原生mysql的批量更新及性能测试
- stm32 USB CDC 不接电脑无程序一直在USB中断问题
- ANDROID 开发常用的框架、工具、API最全集合
- Linux学习总结(二) 网络配置-NAT方式静态IP配置篇
- TensorflowSharp 简单使用与KNN识别MNIST流程
- java ee jms_Java EE6事件:JMS的轻量级替代品
- 【LeetCode-SQL每日一练】—— 1179. 重新格式化部门表
- 使用JavaScript和D3.js实现数据可视化
- tensorflow之FIFOQueue
- 格符\b的使用示例:每隔1秒消去1个字符
- EditPlus批量转码
- flash cs4 打不开的解决方法(启动界面一闪而过)
- HTML用户名判断,用户名判断(练习)
- 【kali】kali2020.2安装 超级详细教程
- 记录自己从零开始创建个人小程序到发布的大致过程
- Linux rpm -ivm,PowerLinux 7R1项目实施手册PDF
- python全套数据分析课程_B 站疯传,堪称最强,一整套Python数据分析课程,学完月薪30K+!...
- 《程序员》约稿:多任务下的时间管理,目标计划与任务分解
- pdf解密,pdf,jpg,word格式互相转换
- OBM,ODM,OEM分别指什么