java目前常用的几种定时任务
java目前常用的几种定时任务
一、JDK自带的Timer
Timer是jdk中提供的一个定时器工具,使用的时候会在主线程之外起一个单独的线程执行指定的计划任务,可以指定执行一次或者反复执行多次。
TimerTask是一个实现了Runnable接口的抽象类,代表一个可以被Timer执行的任务。
1 import org.junit.Test;
2 import java.util.Timer;
3 import java.util.TimerTask;
4
5 public class TimerTest {
6 @Test
7 public void test(){
8 Timer timer = new Timer();
9 TimerTask timerTask = new TimerTask() {
10 @Override
11 public void run() {
12 System.out.println("当前时间");//具体的任务
13 }
14 };
15 timer.schedule(timerTask1,1000,1000);//任务,开始时间ms,间隔ms
16 System.out.println("start");
17 try {
18 Thread.sleep(2000);//不停两秒,显示不出来,因为test情况下当前用户线程结束,可是定时任务1s还没开始,就被终止
19 }catch (Exception e) {
20
21 }
22 System.out.println("end");
23 }
24 }
终止timer的方式
- 调用timer的cancle方法,
- 把timer线程设置成daemon线程,(new Timer(true)创建daemon线程),在jvm里,如果所有用户线程结束,那么守护线程也会被终止,不过这种方法一般不用。
- 当所有任务执行结束后,删除对应timer对象的引用,线程也会被终止。
- 调用System.exit方法终止程序
注意点
- 每一个Timer仅对应唯一一个线程。
- Timer不保证任务执行的十分精确, schedule如果某一次调度时间比较长,那么后面的时间会顺延和scheduleAtFixedRate(严格按照调度时间来的,如果某次调度时间太长了,那么会通过缩短间隔的方式保证下一次调度在预定时间执行)会有不同的时间差。
- Timer类的线程安全的
- jdk1.5之后,ScheduledExecutorService代替了Timer来实现任务调度,加入了线程池等特性。
二、spring的Task
Task底层的实现,使用的ScheduledExecutorService。
2.1、注解的形式
使用@EnableScheduling启动定时任务注解解析,之后@Schedule写在执行的任务上即可
[cron表达式详解](https://www.jianshu.com/p/1defb0f22ed1)
2.2、直接代码的形式
1 @EnableScheduling
2 public class Task {
3
4 @Scheduled(zone = "Asia/Beijing",cron = "0/10 * * * * * *")//zone表示时区
5 public void schedule4(){
6 }
7 /*
8 fixedDelay对应的fixedDelayString支持字符串形式、占位符${}|#{}
9 */
10 @Scheduled(fixedDelay = 5000)//上一次执行完毕时间点之后多长时间再执行
11 public void schedule1(){
12 }
13 @Scheduled(fixedRate = 5000)//上一次开始执行时间点之后多长时间再执行
14 public void schedule2(){
15 }
16 @Scheduled(initialDelay = 5000)//第一次延迟多长时间后再执行
17 public void schedule3(){
18 }
19
20 }
TaskScheduler的子类
ConcurrentTaskScheduler:以当前线程执行任务。如果任务简单,可以直接使用这个类来执行。快捷方便。
DefaultManagedTaskScheduler:以当前线程执行任务,这是ConcurrentTaskScheduler的子类,添加了JNDI的支持。和ConcurrentTaskScheduler一样的用法,需要使用JNDI可以单独设置
ThreadPoolTaskScheduler:TaskScheduler接口的默认实现类,多线程定时任务执行。<font color=#0075EA>可以设置执行线程池数(默认一个线程),使用前必须得先调用initialize()【初始化方法】,有shutDown()方法,执行完后可以关闭线程</font>。
TimerManagerTaskScheduler:用于包装CommonJ中的TimerManager接口。在使用CommonJ进行调度时使用。(没有使用过)
三、Quartz
四、elastic-job分布式定时任务
基于Zookepper和Quartz开发,并且开源的Java分布式定时任务,解决Quartz不支持分布式的弊端,Elastic-Job采用分片的方式,是分布式调度解决方案。适用场景是:相对于流程比较简单,但是任务可以拆分到多个线程去执行。 每个任务都使用独立的线程池。
1 //注册zookeeper
2 @Bean(initMethod = "init")
3 public ZookeeperRegistryCenter regCenter( final String serverList,final String namespace) {
4 return new ZookeeperRegistryCenter(new ZookeeperConfiguration(serverList, namespace));
5 }
1 //配置任务config
2 @Configuration
3 public class LoginOverdueJobConfig {
4 @Resource
5 private ZookeeperRegistryCenter regCenter;
6
7 @Resource
8 private JobEventConfiguration jobEventConfiguration;
9
10 private LiteJobConfiguration getLiteJobConfiguration(final Class<? extends SimpleJob> jobClass, final String cron, final int shardingTotalCount, final String shardingItemParameters) {
11 return LiteJobConfiguration.newBuilder(new SimpleJobConfiguration(JobCoreConfiguration.newBuilder(
12 jobClass.getName(), cron, shardingTotalCount).shardingItemParameters(shardingItemParameters).build(), jobClass.getCanonicalName())).overwrite(true).build();
13 }
14
15 @Bean(initMethod = "init")
16 public JobScheduler simpleCloudStorageJobScheduler(final LoginOverdueJob loginOverdueJob, @Value("${simpleJob.cron}") final String cron, @Value("${simpleJob.shardingTotalCount}") final int shardingTotalCount,
17 @Value("${simpleJob.shardingItemParameters}") final String shardingItemParameters) {
18 return new SpringJobScheduler(loginOverdueJob, regCenter, getLiteJobConfiguration(loginOverdueJob.getClass(), cron, shardingTotalCount, shardingItemParameters), jobEventConfiguration);
19 }
20 }
1 //任务执行函数
2 @Component
3 public class LoginOverdueJob implements SimpleJob {
4 public void execute(ShardingContext shardingContext) {
5
6 }
7 }
java目前常用的几种定时任务的更多相关文章
- Java中常用的四种线程池
在Java中使用线程池,可以用ThreadPoolExecutor的构造函数直接创建出线程池实例,如何使用参见之前的文章Java线程池构造参数详解.不过,在Executors类中,为我们提供了常用线程 ...
- java中常用的几种缓存类型介绍
在平时的开发中会经常用到缓存,比如locache.redis等,但一直没有对缓存有过比较全面的总结.下面从什么是缓存.为什么使用缓存.缓存的分类以及对每种缓存的使用分别进行分析,从而对缓存有更深入的了 ...
- java最常用的几种加密算法
1. BASE64 Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递 ...
- java map常用的4种遍历方法
public static void main(String[] args) { Map<String, String> map = new HashMap<String, Stri ...
- Java中常用的6种排序算法详细分解
排序算法很多地方都会用到,近期又重新看了一遍算法,并自己简单地实现了一遍,特此记录下来,为以后复习留点材料. 废话不多说,下面逐一看看经典的排序算法: 1. 选择排序 选择排序的基本思想是遍历数组的过 ...
- java常用的几种线程池比较
1. 为什么使用线程池 诸如 Web 服务器.数据库服务器.文件服务器或邮件服务器之类的许多服务器应用程序都面向处理来自某些远程来源的大量短小的任务.请求以某种方式到达服务器,这种方式可能是通过网络协 ...
- java线程池与五种常用线程池策略使用与解析
背景:面试中会要求对5中线程池作分析.所以要熟知线程池的运行细节,如CachedThreadPool会引发oom吗? java线程池与五种常用线程池策略使用与解析 可选择的阻塞队列BlockingQu ...
- java算法03 - 常用的8种排序算法
Java常用的八种排序算法: 插入排序 - 直接插入排序 每次将待排序的记录按照关键字的大小,插入到前面已经排好序的记录的适当位置.直到全部记录插入完成. 代码实现 /** * 直接插入排序 O(n^ ...
- java 获取键盘输入常用的两种方法
java 获取键盘输入常用的两种方法 方法1: 通过 Scanner Scanner input = new Scanner(System.in); String s = input.nextLine ...
随机推荐
- hihoCoder 1040 矩阵判断 最详细的解题报告
题目来源:矩阵判断 解题思路: 1.判断矩阵的4个点是否相连,一共输入8个点,只要判断是否4个点是否都经过2遍: 2.判断矩阵中任意一条边与其他边之间要么平行,要么垂直.设A(x1,y1),B(x2, ...
- bzoj3446[Usaco2014 Feb]Cow Decathlon*
bzoj3446[Usaco2014 Feb]Cow Decathlon 题意: FJ有n头奶牛.FJ提供n种不同的技能供奶牛们学习,每头奶牛只能学习一门技能,每门技能都要有奶牛学习. 第i头奶牛学习 ...
- Azure 提供负载均衡(一)Azure Traffic Manager 为我们的Web项目提供负载均衡
一,引言 上一篇讲到我们将自己的Net Core Web 项目部署到 Azure 的 Web App 的一项 pass 服务,假如随着项目的日益增长的访问量,之前部署到单节点的应用可能无法保证其稳定性 ...
- msf stagers开发不完全指北(四): msf 中使用域前置技术隐藏流量
msf 中使用域前置技术隐藏流量 前几篇都是说了下如何采用不同的语言开发 reverse_tcp 第二阶段,接下来将慢慢分析 reverse_http,这篇文章并不会围绕 stagers 进行讲解,这 ...
- Shell基本语法---函数
函数 函数定义 function 函数名 () { 指令... return n } 函数调用及参数传递 function func() { echo "第零个参数:" $ #脚本 ...
- 使用python打造一款音乐播放器
作者qq:64761294 编程/考试交流群:834531270 欢迎交流 核心播放模块(pygame内核) import time import pygame import easygui as g ...
- js异步执行原理
我们都知道js是一个单线程的语言,所以没办法同时执行俩个进程.所以我们就会用到异步. 异步的形式有哪些那,es5的回调函数.es6的promis等 异步的运行原理我们可以先看下面这段代码 应该很多人都 ...
- js获取json对象的属性值
// var responseData = response.data.result; for (var r in responseData) { ...
- 使用AB对Nginx压测和并发预估
简介 ab命令会创建多个并发访问线程,模拟多个访问者同时对某一URL地址进行访问.它的测试目标是基于URL的. # 1.ab每次只能测试一个URL,适合做重复压力测试 # 2.参数很多,可以支持添加c ...
- 浅谈NTLM Hash
认识Windows Hash 早期SMB协议在网络上传输明文口令.后来出现LAN Manager 挑战/响应验证机制(LM),其很容易破解,因此微软提出了WindowsNT挑战/响应验证机制(NTLM ...