一、定时任务

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):定时任务和异步任务的使用方式相关推荐

  1. SpringBoot2.0基础案例分类总结,后续更新计划说明

    一.基础案例 1.基础案例概览 历时一个半月,SpringBoot2.0基础案例的文章基本更新完毕了,基础案例包含了SpringBoot的基础教程,高级应用,日志配置,数据库使用,事务管理等.关于Sp ...

  2. SpringBoot2.0 基础案例(12):基于转账案例,演示事务管理操作

    本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.事务管理简介 1.事务基本概念 一组业务操作ABCD,要么全部 ...

  3. SpringBoot2.0 基础案例(14):基于Yml配置方式,实现文件上传逻辑

    本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.文件上传 文件上传是项目开发中一个很常用的功能,常见的如头像上 ...

  4. SpringBoot2.0 基础案例(13):基于Cache注解模式,管理Redis缓存

    本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.Cache缓存简介 从Spring3开始定义Cache和Cac ...

  5. SpringBoot2.0基础案例(01):环境搭建和RestFul风格接口

    一.SpringBoot 框架的特点 SpringBoot2.0 特点 1)SpringBoot继承了Spring优秀的基因,上手难度小 2)简化配置,提供各种默认配置来简化项目配置 3)内嵌式容器简 ...

  6. SpringBoot2.0 基础案例(16):配置Actuator组件,实现系统监控

    本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.Actuator简介 1.监控组件作用 在生产环境中,需要实时 ...

  7. SpringBoot2.0 基础案例(15):配置MongoDB数据库,实现增删改查逻辑

    本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.NoSQL简介 1.NoSQL 概念 NoSQL( Not O ...

  8. SpringBoot2.0 基础案例(10):整合Mybatis框架,集成分页助手插件

    一.Mybatis框架 1.mybatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获 ...

  9. SpringBoot2.0 基础案例(09):集成JPA持久层框架,简化数据库操作

    一.JAP框架简介 JPA(Java Persistence API)意即Java持久化API,是Sun官方在JDK5.0后提出的Java持久化规范.主要是为了简化持久层开发以及整合ORM技术,结束H ...

最新文章

  1. 原生mysql的批量更新及性能测试
  2. stm32 USB CDC 不接电脑无程序一直在USB中断问题
  3. ANDROID 开发常用的框架、工具、API最全集合
  4. Linux学习总结(二) 网络配置-NAT方式静态IP配置篇
  5. TensorflowSharp 简单使用与KNN识别MNIST流程
  6. java ee jms_Java EE6事件:JMS的轻量级替代品
  7. 【LeetCode-SQL每日一练】—— 1179. 重新格式化部门表
  8. 使用JavaScript和D3.js实现数据可视化
  9. tensorflow之FIFOQueue
  10. 格符\b的使用示例:每隔1秒消去1个字符
  11. EditPlus批量转码
  12. flash cs4 打不开的解决方法(启动界面一闪而过)
  13. HTML用户名判断,用户名判断(练习)
  14. 【kali】kali2020.2安装 超级详细教程
  15. 记录自己从零开始创建个人小程序到发布的大致过程
  16. Linux rpm -ivm,PowerLinux 7R1项目实施手册PDF
  17. python全套数据分析课程_B 站疯传,堪称最强,一整套Python数据分析课程,学完月薪30K+!...
  18. 《程序员》约稿:多任务下的时间管理,目标计划与任务分解
  19. pdf解密,pdf,jpg,word格式互相转换
  20. OBM,ODM,OEM分别指什么

热门文章

  1. (王道408考研操作系统)第二章进程管理-第二节4:调度算法详解2(RR、HPF和MFQ)
  2. Linux 调整内核参数
  3. 编译原理中词法分析--部分实现
  4. 动图(gif文件)的最简单制作---------录制
  5. 脏牛Linux本地提权漏洞复现(CVE-2016-5195、Linux、Android、提权)
  6. JS 向未声明的变量分配值(可删除)
  7. nDPI流量协议分析(应用软件识别)
  8. python里的文件I/O
  9. 使用Huploadify上传文件并动态传递参数到后台
  10. 两种计算器小程序对比