java jobkey_quartz2.3.0(十二)通过RMI协议向Scheduler调度器远程添加job任务

此代码示例通过RMI协议向Scheduler调度器远程添加job任务。

代码文件包括:job任务类(SimpleJob.java)、RMI服务端server类(RemoteServerExample.java)、RMI客户端client类(RemoteClientExample.java)。

注意:job任务类与client客户端在同一个应用里。

RMI服务端server类(RemoteServerExample.java)

先设置server端的定时配置quartz.properties

#============================================================================# Configure Main Scheduler Properties

#============================================================================org.quartz.scheduler.instanceName: Sched1

org.quartz.scheduler.rmi.export:true //重点org.quartz.scheduler.rmi.registryHost: localhost //重点

org.quartz.scheduler.rmi.registryPort: 1099 //重点org.quartz.scheduler.rmi.createRegistry:true#============================================================================# Configure ThreadPool

#============================================================================org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool

org.quartz.threadPool.threadCount:10org.quartz.threadPool.threadPriority:5#============================================================================# Configure JobStore

#============================================================================org.quartz.jobStore.misfireThreshold:60000org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore

RemoteServerExample.java 类代码:

packageorg.quartz.examples.example12;importorg.quartz.Scheduler;importorg.quartz.SchedulerFactory;importorg.quartz.SchedulerMetaData;importorg.quartz.impl.StdSchedulerFactory;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;/*** 这个示例将生成大量要运行的作业*/

public classRemoteServerExample {

Logger LOG= LoggerFactory.getLogger(RemoteServerExample.class);public void run() throwsException {//初始化一个调度工厂,并实例化一个调度类

SchedulerFactory sf = newStdSchedulerFactory();

Scheduler sched=sf.getScheduler();

sched.start();try{

Thread.sleep(300L * 1000L);

}catch(Exception e) {//}

sched.shutdown(true);

LOG.info("------- Shutdown Complete -----------------");

SchedulerMetaData metaData=sched.getMetaData();

LOG.info("Executed " + metaData.getNumberOfJobsExecuted() + " jobs.");

}public static void main(String[] args) throwsException {

RemoteServerExample example= newRemoteServerExample();

example.run();

}

}

job任务类(SimpleJob.java)

packageorg.quartz.examples.example12;importjava.util.Date;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importorg.quartz.Job;importorg.quartz.JobExecutionContext;importorg.quartz.JobExecutionException;importorg.quartz.JobKey;/*** 一个愚蠢的作业实现,用于单元测试。*/

public class SimpleJob implementsJob {public static final String MESSAGE = "msg";private static Logger LOG = LoggerFactory.getLogger(SimpleJob.class);//必须要有public修饰的无参构造函数

publicSimpleJob() {

}//任务执行方法

public void execute(JobExecutionContext context) throwsJobExecutionException {

JobKey jobKey=context.getJobDetail().getKey();

String message=(String) context.getJobDetail().getJobDataMap().get(MESSAGE);

LOG.info("任务执行1。SimpleJob: " + jobKey + " executing at " + newDate());

LOG.info("任务执行2。SimpleJob: msg: " +message);

}

}

RMI客户端client类(RemoteClientExample.java)

设置client端的定时配置quartz.properties

org.quartz.scheduler.instanceName: Sched1

org.quartz.scheduler.logger: schedLogger

org.quartz.scheduler.rmi.proxy:true //重点

org.quartz.scheduler.rmi.registryHost: localhost //重点

org.quartz.scheduler.rmi.registryPort: 1099 //重点

RemoteClientExample.java类代码:

packageorg.quartz.examples.example12;import staticorg.quartz.CronScheduleBuilder.cronSchedule;import staticorg.quartz.JobBuilder.newJob;import staticorg.quartz.TriggerBuilder.newTrigger;importorg.quartz.JobDataMap;importorg.quartz.JobDetail;importorg.quartz.Scheduler;importorg.quartz.SchedulerFactory;importorg.quartz.Trigger;importorg.quartz.impl.StdSchedulerFactory;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;/*** 这个示例是一个客户机程序,它将与调度程序进行远程通信以调度作业。

* 在本例中,我们将需要使用JDBC作业存储。客户机将远程连接到JDBC作业存储以调度作业。*/

public classRemoteClientExample {static Logger LOG = LoggerFactory.getLogger(RemoteClientExample.class);public void run() throwsException {//初始化一个调度工厂,并实例化一个调度类

SchedulerFactory sf = newStdSchedulerFactory();

Scheduler sched=sf.getScheduler();//定义一个job任务,远程添加到调度器的任务//group: default, job: remotelyAddedJob

JobDetail job = newJob(SimpleJob.class)

.withIdentity("remotelyAddedJob", "default")

.build();

JobDataMap map=job.getJobDataMap();

map.put("msg", "Your remotely added job has executed!");

Trigger trigger=newTrigger()

.withIdentity("remotelyAddedTrigger", "default")

.forJob(job.getKey())

.withSchedule(cronSchedule("0/2 * * * * ?"))

.build();

sched.scheduleJob(job, trigger);

LOG.info("Remote job scheduled.");

}public static void main(String[] args) throwsException {

RemoteClientExample example= newRemoteClientExample();

example.run();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值