Hybris CronJob

简介: 一、概念     CronJobs提供了在特定的时间或者间隔内处理业务逻辑的方法。一般创建一个Cronjob有两种方式,第一种是定义Java类,由Hybris生成脚本并加入数据库。第二种是直接编写groovy脚本语言并插入数据库,这种应该适合逻辑比较少的时候,比如只有一两句逻辑的时候,一般用得比较少。

一、概念

    CronJobs提供了在特定的时间或者间隔内处理业务逻辑的方法。一般创建一个Cronjob有两种方式,第一种是定义Java类,由Hybris生成脚本并加入数据库。第二种是直接编写groovy脚本语言并插入数据库,这种应该适合逻辑比较少的时候,比如只有一两句逻辑的时候,一般用得比较少。

 

二、定义Java类创建CronJobs

1、先写要实现的job类

public class SyncAliExpressOrder extends AbstractJobPerformable<CronJobModel>//需要继承这个类
{
    private static final Logger LOG = Logger.getLogger(SyncAliExpressOrder.class);
    private SyncAliexpressService syncAliexpressService;

    @Override
    public PerformResult perform(CronJobModel cronJobModel)
    {
        String accessToken = syncAliexpressService.getAccessToken();
        List<AliExpressTradeModel> list=new ArrayList<>();
        syncAliexpressService.findOrderListQuery(list);//这里调用自己要完成的业务逻辑
        LOG.info("Hello World!");

        if (accessToken!=null) {
            LOG.info("+success+");
            return new PerformResult(CronJobResult.SUCCESS, CronJobStatus.FINISHED);//成功返回这个
        }else{
            LOG.info("=failure=");
            return new PerformResult(CronJobResult.FAILURE, CronJobStatus.ABORTED);//失败返回这个
        }
    }

    public SyncAliexpressService getSyncAliexpressService()
    {
        return syncAliexpressService;
    }

    public void setSyncAliexpressService(SyncAliexpressService syncAliexpressService)
    {
        this.syncAliexpressService = syncAliexpressService;
    }
}

 备注:记得要在Spring中配置bean哦、

 

2、生成Cronjob,并加上触发器

INSERT_UPDATE ServicelayerJob;code[unique=true];springId
;syncAliExpressOrder;syncAliExpressOrder

INSERT_UPDATE CronJob;code[unique=true];job(code);singleExecutable;sessionLanguage(isocode)
;syncAliExpressOrderCronJob;syncAliExpressOrder;false;en

INSERT_UPDATE Trigger;cronjob(code)[unique=true];cronExpression
;syncAliExpressOrderCronJob;0 0 12 ? * WED

 

备注:ServicelayerJob的code和我们定义的job类的名字一致,CronJob的job关联到我们定义的ServicelayerJob,接着定义触发器Trigger,用到的语法主要是Cron表达式,接下来会说到。

 

三、直接编写IMPEX脚本,生成CronJobs

 INSERT_UPDATE Script;code[unique=true];content 
 ;myGroovyScript;println 'Hello World! '

 INSERT_UPDATE ScriptingJob;code[unique=true];scriptURI
 ;mydynamicJob;model://myGroovyScript

 INSERT_UPDATE CronJob;code[unique=true];job(code);singleExecutable;sessionLanguage(isocode)
 ;mydynamicCronJob;mydynamicJob;true;en

 INSERT_UPDATE Trigger;cronjob(code)[unique=true];cronExpression
 ;mydynamicCronJob;1/5 * * * * ?

备注:这里通过编写脚本的内容content来实现业务(不过业务也不是一两句话可以实现的,所以这种方法只适合自己玩玩啦),content的脚本用Groovy语言写的,其他的就没差啦

 

四、quartz CronExpression表达式

    一个cron表达式有至少6个(也可能7个)有空格分隔的时间元素。按顺序依次为1.秒(0~59)2.分钟(0~59)3.小时(0~23)4.天(月)(0~31,但是你需要考虑你月的天数)5.月(0~11)6.天(星期)(1~71=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)7.年份(1970-2099)。其中每个元素可以是一个值(如6),一个连续区间(9-12),一个间隔时间(8-18/4)(/表示每隔4小时),一个列表(1,3,5),通配符。 由于"月份中的日期"和"星期中的日期"这两个元素互斥的,必须要对其中一个设置 ?
 
通配符说明:
  • * 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。
  • ? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为 00010 * ?
  • - 表示区间。例如 在小时上设置 "10-12",表示 10,11,12点都会触发。
  • , 表示指定多个值,例如在周字段上设置 "MON,WED,FRI" 表示周一,周三和周五触发
  • / 用于递增触发。如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50);在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。
  • L 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]),
  • 在周字段上 "7"或"SAT"表示星期六,
  • 如果在"L"前加上数字,则表示该数据的最后一个。例如在周字段上设置"6L"这样的格式,则表示“本月最后一个星期五"
  • W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 "1W",它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,"W"前只能设置具体的数字,不允许区间"-")
  • # 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用在母亲节和父亲节再合适不过了) ;
  • 小提示:'L'和 'W'可以一组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发;周字段的设置,若使用英文字母是不区分大小写的,即MON与mon相同;
 
常用示例:
  • 0 0 10,14,16 * * ?  每天上午10点,下午2点
  • 0 0/30 9-17 * * ? ?  朝九晚五工作时间内每半小时
  • 0 0 12 ? *  WED 表示每个星期三中午12点
  • 0 0 12 * * ?  每天12点触发
  • 0 15 10 ? * *  每天10点15分触发
  • 0 15 10 * * ?  每天10点15分触发
  • 0 15 10 * * ? *  每天10点15分触发
  • 0 15 10 * * ? 2005 2005年每天10点15分触发
  • 0 * 14 * * ?  每天下午的 2点到2点59分每分触发
  • 0 0/5 14 * * ?  每天下午的 2点到2点59分(整点开始,每隔5分触发)
  • 0 0/5 14,18 * * ?  每天下午的 2点到2点59分、18点到18点59分(整点开始,每隔5分触发)
  • 0 0-5 14 * * ?  每天下午的 2点到2点05分每分触发
  • 0 10,44 14 ? 3 WED  3月分每周三下午的 2点10分和2点44分触发
  • 0 15 10 ? *  MON-FRI 从周一到周五每天上午的10点15分触发
  • 0 15 10 15 * ?  每月15号上午10点15分触发
  • 0 15 10 L * ?  每月最后一天的10点15分触发
  • 0 15 10 ? * 6L 每月最后一周的星期五的10点15分触发
  • 0 15 10 ? * 6L2002-2005 从2002年到2005年每月最后一周的星期五的10点15分触发
  • 01510 ? * 6#3  每月的第三周的星期五开始触发
  • 0 0 121/5 * ?  每月的第一个中午开始每隔5天触发一次
  • 0 11 11 11 11 ?  每年的11月11号 11点11分触发(光棍节)

 

五、运行Cronjob

 

目录
相关文章
|
人工智能 Kubernetes Cloud Native
进击的 Kubernetes 调度系统(一):Kubernetes scheduling framework
阿里云容器服务团队结合多年 Kubernetes 产品与客户支持经验,对 Kube-scheduler 进行了大量优化和扩展,逐步使其在不同场景下依然能稳定、高效地调度各种类型的复杂工作负载。《进击的 Kubernetes 调度系统》系列文章将把我们的经验、技术思考和实现细节全面地展现给 Kubernetes 用户和开发者,期望帮助大家更好地了解 Kubernetes 调度系统的强大能力和未来发展方向。
进击的 Kubernetes 调度系统(一):Kubernetes scheduling framework
|
Kubernetes Cloud Native Ubuntu
【探索 Kubernetes|作业管理篇 系列 16】离线业务 Job、CronJob
大家好,我是秋意零。 在上一篇中,我们讲解了 DaemonSet 控制器,相信你以及理解了其的工作过程,分为三部。一是,获取所有 Node 节点中的 Pod;二是,判断是否有符合 DaemonSet 管理的 Pod;三是,通过“亲和性”和“容忍”来精确控制并保证 Pod 在目标节点运行。 今天的内容是 Job 与 CronJob 离线业务控制器。
421 1
|
存储 Kubernetes 监控
【探索 Kubernetes|作业管理篇 系列 15】DaemonSet 的”过人之处“
【探索 Kubernetes|作业管理篇 系列 15】DaemonSet 的”过人之处“
113 0
|
Kubernetes API 容器
开发 k8s 管理平台 - k8sailor 20. 为 Deployment 创建 Ingress
开发 k8s 管理平台 - k8sailor 20. 为 Deployment 创建 Ingress
190 0
开发 k8s 管理平台 - k8sailor 20. 为 Deployment 创建 Ingress
|
Java Unix Linux
kubernete编排技术四:Job和CronJob
kubernete编排技术四:Job和CronJob
120 0
kubernete编排技术四:Job和CronJob
|
存储 JSON Kubernetes
kubernetes Auditing 实战
kubernetes Auditing 实战
kubernetes Auditing 实战
|
机器学习/深度学习 存储 Kubernetes
Argo Workflows-Kubernetes的工作流引擎(上)
Argo Workflows-Kubernetes的工作流引擎
Argo Workflows-Kubernetes的工作流引擎(上)
|
JSON 缓存 数据格式
Argo Workflows-Kubernetes的工作流引擎(下)
Argo Workflows-Kubernetes的工作流引擎
Argo Workflows-Kubernetes的工作流引擎(下)
|
Kubernetes Cloud Native 算法
CNCF 沙箱项目 OCM Placement 多集群调度指南
在这篇文章中,将介绍 Placement 如何选择到所需的集群,Placement 可以提供的调度功能,以及一些场景下的最佳实践,使用者可以参考示例来编写符合自己要求的 Placement。其他一些高级调度功能,如支持污点 (taints) 和容忍 (tolerations),以及拓扑选择 (spread),正在 OCM 社区讨论中。
|
Kubernetes Linux 调度
十、kubernetes Job和CronJob
kubernetes Job和CronJob
443 0