SpringBoot整合Quartz-动态读取任务执行(2.2.1)
来源:互联网 发布:windows镜像下载网站 编辑:程序博客网 时间:2024/05/29 17:50
本次使用redis作为数据库,存储定时任务类
redis的连接不是重点,重点是解析序列化处理过的任务数组和Quartz如何添加任务
1. JobEntity 用来保存执行任务类
public class JobEntity implements Serializable { //cron表达式 private String cronExpression; //组名 private String jobGroup = Scheduler.DEFAULT_GROUP; private String jobName; private String className; // 执行任务的类(完整路径 包含包名) private String methodName;//执行任务的方法名 set ... get ...}
2.任务类
public class Test { public void xun(){ System.out.println("--------定时任务2-------"); }}public class Test2 { public void test(){ System.out.println("--------定时任务1-------"); }}
3.存入redis
public void start2() { Gson gson = new Gson(); JobEntity jobEntity = new JobEntity(); jobEntity.setMethodName("test"); jobEntity.setJobName("MyJob2"); jobEntity.setClassName("zebra.shjf.schedule.Test2"); jobEntity.setCronExpression("0/1 * * * * ?"); jobEntity.setJobGroup("MyGroup2"); JobEntity jobEntity2 = new JobEntity(); jobEntity2.setMethodName("xun"); jobEntity2.setJobName("MyJob"); jobEntity2.setClassName("zebra.shjf.schedule.Test"); jobEntity2.setCronExpression("0/1 * * * * ?"); jobEntity2.setJobGroup("MyGroup"); ArrayList<JobEntity> list = new ArrayList<JobEntity>(); list.add(jobEntity); list.add(jobEntity2); jedis.set("jobEntity", gson.toJson(list)); } 127.0.0.1:6379> get "jobEntity" "[{\"cronExpression\":\"0/1 * * * * ?\",\"jobGroup\":\"MyGroup2\",\"jobName\":\"MyJob2\",\"className\":\"zebra.shjf.schedule.Test2\",\"methodName\":\"test\"},{\"cronExpression\":\"0/1 * * * * ?\",\"jobGroup\":\"MyGroup\",\"jobName\":\"MyJob\",\"className\":\"zebra.shjf.schedule.Test\",\"methodName\":\"xun\"}]"
3.重点解析(注释解释)
@Test public void start3() throws Exception { //准备添加从redis中得到的实体类,目的是遍历,然后添加到定时容器中,去执行 ArrayList<JobEntity>arrayList=new ArrayList<JobEntity>(); Gson gson = new Gson(); //从redis中得到json数组对象 String str = jedis.get("jobEntity"); //json解析器 JsonParser parser = new JsonParser(); //解析出json元素,jsonElement对象中有一些方法判断是对象还是数组,各对应不同的处理 JsonElement jsonElement = parser.parse(str); //如果是json数组就转换为jsonArray JsonArray jsonArray = null; if (jsonElement.isJsonArray()) { jsonArray = jsonElement.getAsJsonArray(); } //遍历 Iterator it= jsonArray.iterator(); while (it.hasNext()){ JsonElement e = (JsonElement)it.next(); //把获得的数组中每一个对象,重新添加到数组中 arrayList.add(gson.fromJson(e,JobEntity.class)); } //容器 Scheduler scheduler=null; //遍历数组 for(JobEntity jobEntity:arrayList){ //遍历获得每个job对象 JobDetail jobDetail = JobBuilder.newJob(ScheduledTasks.class).withIdentity(jobEntity.getJobName(), jobEntity.getJobGroup()).// usingJobData("className", jobEntity.getClassName()) .usingJobData("methodName", jobEntity.getMethodName()).build(); //jobDetail.getJobDataMap().put("test", jobEntity); //为每个任务动态构建表达式 CronScheduleBuilder cron = CronScheduleBuilder.cronSchedule(jobEntity.getCronExpression()); //构建触发器 CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(jobEntity.getJobName(), jobEntity.getJobGroup()).withSchedule(cron).build(); SchedulerFactory schedulerFactory = new StdSchedulerFactory(); scheduler = schedulerFactory.getScheduler(); scheduler.scheduleJob(jobDetail, trigger); } scheduler.start(); Thread thread = new Thread(); thread.sleep(10000); }
阅读全文
0 0
- SpringBoot整合Quartz-动态读取任务执行(2.2.1)
- SpringBoot整合Quartz-动态读取任务执行(2.2.1)
- springboot动态配置定时任务2种方式,整合Quartz多线程并发执行多个定时任务配置
- springboot动态配置定时任务2种方式,整合Quartz多线程并发执行多个定时任务配置
- springboot整合Quartz实现动态配置定时任务
- springboot整合Quartz实现动态配置定时任务
- springboot整合Quartz实现动态配置定时任务
- springboot quartz 多任务整合
- spring3.2.0 quartz-2.2.1 整合 实现动态定时任务
- springboot整合quartz实现定时任务
- 6. springboot整合quartz实现定时任务
- springBoot整合quartz(多任务)
- 定时任务quartz与spring整合(springboot)
- springboot整合quartz实现定时任务
- SpringBoot整合Quartz 2实现定时任务之一:整合
- (一)spring3.2.0 quartz-2.2.1 整合 实现动态定时任务 解决service为null问题
- Spring整合Quartz实现动态定时任务
- Spring 整合 Quartz 实现动态定时任务
- CentOS7.2系统下使用node-fontnik将tff字体转pbf字体
- 隐藏UITableView的滚动条以及修改滚动条的颜色
- StringBoot整合Shiro
- 程序员必须掌握的8种排序算法(八):基数排序
- Java锁的种类和区别
- SpringBoot整合Quartz-动态读取任务执行(2.2.1)
- SIM上运营商SPN(Service Provider Name)的读取
- Springboot系列文章
- 熵的通俗理解
- SpringBoot集成Rabbit使用TopicRabbit指定发送集合
- Spring之ioc操作与属性注入
- 输出100-500之间的水仙花数
- 数据库
- Hive(十八)--全局排序