java流水调度_java任务调度简单示例

TimeTask

public class DemoTimeTask {

public static void main(String[] args) {

Timer timer = new Timer();

timer.schedule(new TimerTask() {

@Override

public void run() {

System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));

}

}, 0, 1000 * 2);//延迟0秒,间隔2秒

}

}

ScheduledExecutorService

public class DempScheduledExecutorService {

public static void main(String[] args) {

ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();

service.scheduleAtFixedRate(new Runnable() {

public void run() {

System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));

}

}, 0, 1000 * 2, TimeUnit.MILLISECONDS);//延迟0秒,间隔2秒

}

}

springboot

启动类添加@EnableScheduling

@Component

public class MyJob {

@Scheduled(initialDelay = 0, fixedDelay = 1000)

public void job1() {

System.out.println("我是job1:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));

}

@Scheduled(cron = "*/2 * * * * ?")

public void job2() {

System.out.println("我是job2:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));

}

}

quartz

1.pom依赖

org.quartz-scheduler

quartz

2.2.1

org.quartz-scheduler

quartz-jobs

2.2.1

2.任务类

public class MyJob implements Job {

public void execute(JobExecutionContext context) throws JobExecutionException {

System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));

}

}

3.启动类

public class AppQuartz {

public static void main(String[] args) throws SchedulerException {

//1.创建Scheduler的工厂

SchedulerFactory sf = new StdSchedulerFactory();

//2.从工厂中获取调度器实例

Scheduler scheduler = sf.getScheduler();

//3.创建JobDetail

JobDetail jb = JobBuilder.newJob(MyJob.class)

.withDescription("this is a ram job") //job的描述

.withIdentity("ramJob", "ramGroup") //job 的name和group

.build();

//任务运行的时间,SimpleSchedle类型触发器有效

long time = System.currentTimeMillis() + 3 * 1000L; //3秒后启动任务

Date statTime = new Date(time);

//4.创建Trigger

//使用SimpleScheduleBuilder或者CronScheduleBuilder

Trigger t = TriggerBuilder.newTrigger()

.withDescription("")

.withIdentity("ramTrigger", "ramTriggerGroup")

//.withSchedule(SimpleScheduleBuilder.simpleSchedule())

.startAt(statTime) //默认当前时间启动

.withSchedule(CronScheduleBuilder.cronSchedule("0/2 * * * * ?")) //两秒执行一次

.build();

//5.注册任务和定时器

scheduler.scheduleJob(jb, t);

//6.启动 调度器

scheduler.start();

}

}

分布式任务调度XXL-JOB。。。

待完善

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值