elastic-job定时任务

2024-08-26 20:12
文章标签 定时 任务 job elastic

本文主要是介绍elastic-job定时任务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

静态任务案例

​ 使用elastic-job很容易,我们接下来学习下elastic-job的使用,这里的案例我们先实现静态任务案例,静态任务案例也就是执行时间事先写好。

实现步骤:

1.引入依赖包
2.配置zookeeper节点以及任务名称命名空间
3.实现自定义任务,需要实现SimpleJob接口

1)在seckill-goods中引入依赖

<!-- ElasticJobAutoConfiguration自动配置类作用-->
<dependency><groupId>com.github.kuhn-he</groupId><artifactId>elastic-job-lite-spring-boot-starter</artifactId><version>2.1.5</version>
</dependency>

2)配置elastic-job

在bootstrap.yml中配置elastic-job,如下:

elaticjob:zookeeper:server-lists: zk-server:3181namespace: updatetask

讲解:
server-lists:zookeeper的地址
namespace:定时任务命名空间

这里我们只展示了部分常用的参数,还有很多参数,但不一定常用,大家可以参考下面地址学习:

3)任务创建

创建com.seckill.goods.task.statictask.ElasticjobTask,代码如下:

@ElasticSimpleJob(cron = "5/10 * * * * ?",jobName = "updateTask",shardingTotalCount = 1
)
@Component
public class ElasticjobTask implements SimpleJob {/**** 执行任务* @param shardingContext*/@Overridepublic void execute(ShardingContext shardingContext) {System.out.println("-----------执行!");}
}

讲解:

cron:定时表达式
jobName:这里和bootstrap.yml中的namespace保持一致
shardingTotalCount:分片数量

动态任务案例

​ 参考地址:https://github.com/LuoLiangDSGA/spring-learning/tree/master/boot-elasticjob

​动态任务案例主要是讲解程序在运行时,动态添加定时任务,这种场景应用非常广泛。使用elastic-job实现动态添加定时任务的实现有点复杂,我们接下来实际操作一次。

步骤:

1.配置初始化的zookeeper地址
2.配置的定时任务命名空间(不一定会使用)
3.注册初始化数据
4.监听器->任务执行前后监听(可有可无)
5.动态添加定时任务实现
6.自定义任务处理过程-实现SimpleJob

1)监听器创建

​ 监听器采用AOP模式,类似前置通知和后置通知,doBeforeJobExecutedAtLastStarted和doAfterJobExecutedAtLastCompleted分别会在任务执行前和执行后调用,我们创建一个监听器实现任务调度前后拦截,com.seckill.goods.task.dynamic.ElasticJobListener:

public class ElasticJobListener extends AbstractDistributeOnceElasticJobListener {/***** 构造函数* @param startedTimeoutMilliseconds* @param completedTimeoutMilliseconds*/public ElasticJobListener(long startedTimeoutMilliseconds, long completedTimeoutMilliseconds) {super(startedTimeoutMilliseconds, completedTimeoutMilliseconds);}/**** 任务初始化前要做的事情,类似前置通知* @param shardingContexts*/@Overridepublic void doBeforeJobExecutedAtLastStarted(ShardingContexts shardingContexts) {System.out.println("========doBeforeJobExecutedAtLastStarted========"+ TimeUtil.date2FormatHHmmss(new Date()));}/**** 任务执行完成后要做的事情,类似后置通知* @param shardingContexts*/@Overridepublic void doAfterJobExecutedAtLastCompleted(ShardingContexts shardingContexts) {System.out.println("=======doAfterJobExecutedAtLastCompleted============="+ TimeUtil.date2FormatHHmmss(new Date()));}
}

2)注册中心配置

在bootstrap.yml中配置zk和namespace

#配置动态任务案例的zk和namespace

zk: zk-server:3181
namesp: autotask

创建配置类配置注册中心信息,com.seckill.goods.task.dynamic.ElasticJobConfig:

@Configuration
public class ElasticJobConfig {//配置文件中的zookeeper的ip和端口@Value(value = "${zk}")private String serverlists;//指定一个命名空间@Value("${namesp}")private String namespace;/**** 配置Zookeeper和namespace* @return*/@Beanpublic ZookeeperConfiguration zkConfig() {return new ZookeeperConfiguration(serverlists, namespace);}/**** 向zookeeper注册初始化信息* @param config* @return*/@Bean(initMethod = "init")public ZookeeperRegistryCenter regCenter(ZookeeperConfiguration config) {return new ZookeeperRegistryCenter(config);}/***** 创建ElasticJob的监听器实例* @return*/@Beanpublic ElasticJobListener elasticJobListener() {//初始化要给定超时多少秒重连return new ElasticJobListener(100L,100L);}
}

3)任务构建

​ 我们创建一个动态配置任务的类,任何逻辑代码需要创建定时任务,可以直接调用该类的指定方法即可。创建类:com.seckill.goods.task.dynamic.ElasticJobHandler,代码如下:

@Component
public class ElasticJobHandler {@Resourceprivate ZookeeperRegistryCenter registryCenter;@Resourceprivate ElasticJobListener elasticJobListener;/*** @param jobName:任务的命名空间* @param jobClass:执行的定时任务对象* @param shardingTotalCount:分片个数* @param cron:定时周期表达式* @param id:自定义参数* @return*/private static LiteJobConfiguration.Builder simpleJobConfigBuilder(String jobName,Class<? extends SimpleJob> jobClass,int shardingTotalCount,String cron,String id) {//创建任务构建对象LiteJobConfiguration.Builder builder = LiteJobConfiguration.newBuilder(new SimpleJobConfiguration(JobCoreConfiguration.//任务命名空间名字、任务执行周期表达式、分片个数newBuilder(jobName, cron, shardingTotalCount).//自定义参数jobParameter(id).build(),jobClass.getCanonicalName()));//本地配置是否可覆盖注册中心配置builder.overwrite(true);return builder;}/*** 添加一个定时任务* @param cron:周期执行表达式* @param id:自定义参数* @param jobName:命名空间* @param instance:任务对象*/public void addPublishJob(String cron,String id,String jobName,SimpleJob instance) {LiteJobConfiguration jobConfig = simpleJobConfigBuilder(jobName,instance.getClass(),1,cron,id).overwrite(true).build();//DynamicTask为具体的任务执行逻辑类new SpringJobScheduler(instance, registryCenter, jobConfig, elasticJobListener).init();}/**** Date转cron表达式*/public static final String CRON_DATE_FORMAT = "ss mm HH dd MM ? yyyy";/*** 获得定时* @param date* @return*/public static String getCron(final Date date) {SimpleDateFormat simpleDateFormat = new SimpleDateFormat(CRON_DATE_FORMAT);return simpleDateFormat.format(date);}
}

4)执行逻辑

我们接着创建一个类,用于执行自己所需要操作的逻辑,com.seckill.goods.task.dynamic.DynamicTask,代码如下:

public class DynamicTask implements SimpleJob {@Overridepublic void execute(ShardingContext shardingContext) {//传递的参数String id = shardingContext.getJobParameter();try {//具体任务逻辑System.out.println("执行你的逻辑代码!param:"+id);} catch (Exception e) {e.printStackTrace();}}
}

5)调用测试

创建com.seckill.goods.controller.TaskController动态调用创建任务的方法,代码如下:

@RestController
@RequestMapping(value = "/task")
public class TaskController {@AutowiredElasticJobHandler elasticJobHandler;/**** 动态创建任务* @param times:延迟时间,为了测试到效果,所以在当前时间往后延迟* @param jobname:任务名字* @param param:自定义参数* @return*/@GetMappingpublic Result add(Long times,String jobname,String param){//在当前指定时间内延迟times毫秒执行任务Date date = new Date(System.currentTimeMillis()+times);//需要传递给定时任务的参数String cron = ElasticJobHandler.getCron(date);//执行任务elasticJobHandler.addPublishJob(cron,param,jobname,new DynamicTask());return new Result(true, StatusCode.OK,"添加任务成功!");}
}

6)测试

访问:http://localhost:18081/task?times=15000&jobname=asyncname&param=No001

后台执行效果如下:
在这里插入图片描述

这篇关于elastic-job定时任务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109568

相关文章

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

FreeRTOS学习笔记(二)任务基础篇

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、 任务的基本内容1.1 任务的基本特点1.2 任务的状态1.3 任务控制块——任务的“身份证” 二、 任务的实现2.1 定义任务函数2.2 创建任务2.3 启动任务调度器2.4 任务的运行与切换2.4.1 利用延时函数2.4.2 利用中断 2.5 任务的通信与同步2.6 任务的删除2.7 任务的通知2

Flink任务重启策略

概述 Flink支持不同的重启策略,以在故障发生时控制作业如何重启集群在启动时会伴随一个默认的重启策略,在没有定义具体重启策略时会使用该默认策略。如果在工作提交时指定了一个重启策略,该策略会覆盖集群的默认策略默认的重启策略可以通过 Flink 的配置文件 flink-conf.yaml 指定。配置参数 restart-strategy 定义了哪个策略被使用。常用的重启策略: 固定间隔 (Fixe

第49课 Scratch入门篇:骇客任务背景特效

骇客任务背景特效 故事背景:   骇客帝国特色背景在黑色中慢慢滚动着! 程序原理:  1 、 角色的设计技巧  2 、克隆体的应用及特效的使用 开始编程   1、使用 黑色的背景: ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/7d74c872f06b4d9fbc88aecee634b074.png#pic_center)   2

AsyncTask 异步任务解析

1:构建AsyncTask 子类的回调方法: A:doInBackground:   必须重写,所有的耗时操作都在这个里面进行; B: onPreExecute:     用户操作数据前的调用; 例如:显示一个进度条 等 ; C: onPostExecute:    当doInBackground 执行完成后;会自动把数据传给onPostExecute方法;也就是说:这个方法是处理返回的数据的方法

使用Node-API进行异步任务开发

一、Node-API异步任务机制概述         Node-API异步任务开发主要用于执行耗时操作的场景中使用,以避免阻塞主线程,确保应用程序的性能和响应效率。         1、应用场景: 文件操作:读取大型文件或执行复杂的文件操作时,可以使用异步工作项来避免阻塞主线程。网络请求:当需要进行网络请求并等待响应时,可以使用异步工作项来避免阻塞主线程,从而提高应用程序的响应性能。数据库操

探索Invoke:Python自动化任务的瑞士军刀

文章目录 探索Invoke:Python自动化任务的瑞士军刀背景:为何选择Invoke?`invoke`是什么?如何安装`invoke`?简单的`invoke`库函数使用方法场景应用:`invoke`在实际项目中的使用场景一:自动化测试场景二:代码格式化场景三:部署应用 常见问题与解决方案问题一:命令执行失败问题二:权限不足问题三:并发执行问题 总结 探索Invoke:P

RISC-V (十)任务同步和锁

并发与同步 并发:指多个控制流同时执行。         多处理器多任务。一般在多处理器架构下内存是共享的。           单处理器多任务,通过调度器,一会调度这个任务,一会调度下个任务。  共享一个处                                理器一个内存。                 单处理器任务+中断: 同步: 是为了保证在并发执行的环境中各个控制流可

145-Linux权限维持Rootkit后门Strace监控Alias别名Cron定时任务

参考 【权限维持】Linux&Rootkit后门&Strace监控&Alias别名&Cron定时任务_alias ls='alerts(){ ls $* --color=auto;python -c "-CSDN博客 参考 FlowUs 息流 - 新一代生产力工具 权限维持-Linux-定时任务-Cron后门 利用系统的定时任务功能进行反弹Shell 1、编辑后门反弹shell脚本