Spring Boot 定时+多线程执行
Spring Boot 定时任务有多种实现方式,我在一个微型项目中通过注解方式执行定时任务。
具体执行的任务,通过多线程方式执行,单线程执行需要1小时的任务,多线程下5分钟就完成了。
执行效率提升10倍以上,执行效率提升10倍以上,执行效率提升10倍以上。
重要的事情说三遍!
本文不深入介绍具体的原理,大家如果要实现类似的功能,只需要执行下面1~5即可。
至于为什么是上图,而不直接贴代码。直接上代码排版不齐,需要的可以留邮箱,我发给你。
(1)定时任务实现
在需要定时执行的的方法上面增加注解 @Scheduled(cron="01 00 17 * * ?") //[秒] [分] [小时] [日] [月] [周] [年]。
其中cron类似于Linux定时执行的写法,上述表示该任务每天17:00执行一次。
(2)定时任务方法内部多线程执行的部分
需要多线程执行的部分,要重新定义一个类,然后注入该类的变量。如我这里定义了一个类DoBackupTask,在这个类中通过多线程方式执行任务。

(3)多线程实现部分
多线程执行方法上,增加注解@Async("taskExecutor"),参数为线程池的名称

(4)线程池实现
线程池我定义了一个类,在该类中定义了一个方法asyncExecutor。该方法生成ThreadPoolTaskExecutor的一个对象,设置线程数量,线程池的名称等参数。

(5)当上述步骤都做好了,然而并没有效果。可能你漏了最关键的一步:在应用启动类上,增加注解
@EnableScheduling 启用多线程
@EnableAsync 异步执行
如果还是不清楚具体位置,就找@SpringBootApplication这个注解,放在一起就可以了。
Spring Boot 定时+多线程执行的更多相关文章
- 在Spring Boot启动后执行指定代码
		在开发时有时候需要在整个应用开始运行时执行一些特定代码,比如初始化环境,准备测试数据等等. 在Spring中可以通过ApplicationListener来实现相关的功能,不过在配合Spring Bo ... 
- Spring Boot程序的执行流程
		Spring Boot的执行流程如下图所示:(图片来源于网络) 上图为SpringBoot启动结构图,我们发现启动流程主要分为三个部分,第一部分进行SpringApplication的初始化模块,配置 ... 
- spring boot 定时备份数据库
		第一步 :添加mysqldump.exe 进环境变量 第二步 新建一个spring boot 项目,连接数据库 spring.datasource.url=jdbc:mysql://localhos ... 
- Spring Boot Async异步执行
		异步调用就是不用等待结果的返回就执行后面的逻辑,同步调用则需要等带结果再执行后面的逻辑. 通常我们使用异步操作都会去创建一个线程执行一段逻辑,然后把这个线程丢到线程池中去执行,代码如下: Execut ... 
- spring Boot打可执行的jar包
		<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://mave ... 
- Spring Boot实践——多线程
		多线程 Spring通过任务执行器(TaskExecutor)来实现多线程和并发编程.使用ThreadPoolTaskExecutor可实现一个基于线程池的TaskExecutor.而实际开发中任务一 ... 
- Spring Boot 之异步执行方法
		前言: 最近的时候遇到一个需求,就是当服务器接到请求并不需要任务执行完成才返回结果,可以立即返回结果,让任务异步的去执行.开始考虑是直接启一个新的线程去执行任务或者把任务提交到一个线程池去执行,这两种 ... 
- spring boot 启动后执行初始化方法
		http://blog.csdn.net/catoop/article/details/50501710 1.创建实现接口 CommandLineRunner 的类 package org.sprin ... 
- spring boot启动后执行方法
		@Componentpublic class InitProject implements ApplicationRunner { private static final Logger logger ... 
随机推荐
- celery琐碎笔记
			-l 指定日志等级 -n 指定任务名称 -Q 指定任务执行队列 -c 指定启动celery的cpu数量 --logfile 指定日志输出到文件,会输出任务函数里的print,而控制台不会,用于调试. ... 
- input禁止复制、粘贴、剪切
			<input type="text" autocomplete="off"> <!-- autocomplete="off" ... 
- 2019-8-31-dotnet-使用-lz4net-压缩-Stream-或文件
			title author date CreateTime categories dotnet 使用 lz4net 压缩 Stream 或文件 lindexi 2019-08-31 16:55:58 + ... 
- 阿里云PolarDB发布重大更新 支持Oracle等数据库一键迁移上云
			5月21日,阿里云PolarDB发布重大更新,提供传统数据库一键迁移上云能力,可以帮助企业将线下的MySQL.PostgreSQL和Oracle等数据库轻松上云,最快数小时内迁移完成.据估算,云上成本 ... 
- HZOJ 回家
			这篇博客大部分在写我的错解……明明很简单的一道题,知道正解后10分钟AC,然而几个错解打的想死…… 错解1 WA40: 鬼知道这40分哪来的……这也是考试最后很无奈地交上去的代码,最后剩20分钟时发现 ... 
- 深度学习的Xavier初始化方法
			在tensorflow中,有一个初始化函数:tf.contrib.layers.variance_scaling_initializer.Tensorflow 官网的介绍为: variance_sca ... 
- day7_python之面向对象item系列(__getitem__,__setitem__,__delitem__)
			class Foo: def __getitem__(self, item): print('=====>get') return self.__dict__[item] def __setit ... 
- selenium webdriver学习(三)------------执行js脚本
			selenium webdriver学习(三)------------执行js脚本 博客分类: Selenium-webdriver 在用selenium 1.X的时候常常会用到getEval() ... 
- H3C用Telnet登录
- ngRoute
			ngRoute 模块中包含以下内容, 名称 所属 作用 ngView DIRECTIVE 提供不同路由模板插入的视图层 $routeProvider PROVIDER 提供路由配置 $route SE ... 
