最近在忙一个风控项目,其中有一个需求是定时巡检业务中产生的审计数据,寻找其中可能存在的风险数据,以便对对应的违规操作进行管控,避免潜在的资损。我们可爱又牛掰的TL看我最近的绩效在团队中垫底了,为了让我的绩效好看点,于是就把这个任务指派给了我,真是太感动了,感动到流泪~~
好了,背景的确很感动,但是感动之后,我开始搬砖了,不然楼主要卷铺盖走人了。楼主的项目是基于 springboot搭建的, 为了快速实现功能同时减少其他依赖的引入,楼主采用了spring自带的定时任务框架,通过@Scheduled定义具体的定时任务。@Scheduled注解包含一个cron属性,用来指定具体的cron表达式。为了顺利地完成工作,保住饭碗,楼主认真学习总结了cron表达式,其结构如下:
second minute hour dayOfMonth month dayOfWeek year
字段
取值
特殊值
second (秒)
0~59的整数
%2c – * /
minute (分)
0~59的整数
%2c – * /
hour (时)
0~23的整数
%2c – * /
dayOfMonth (日期)
1~31的整数(需要考虑实际的天数)
%2c – * ? / L W C
month (月)
1~12的整数或JAN-DEC
%2c – * /
dayOfWeek (星期)
1~7的整数或SUN-SAT (1=SUN)
%2c – * ? / L C #
year (年,可选的)
1970~2099
%2c – * /
如上图所示,每个域都使用数字,但也可以使用一些特殊字符,其含义如下:
* 匹配该字段域任意值,比如minute域使用*,表示每分钟都会触发事件。
? 只能用在dayOfMonth和dayOfWeek两个域,表示该域匹配任意值或不设置值,且当其中一个域为确定值时,另一个域必须为?(表示另一个域不设置值)。
%2c 表示列举枚举值,比如minute域设为5%2c10%2c15 ,表示在第5、10、15分每分钟执行一次
/ 表示之一次延迟指定时间触发,然后每隔一定时间触发一次(上一次结束与下一次开始之间的时间间隔),比如second域设为0/5,表示0秒触发一次,每次执行完成之后隔5秒再触发下一次
L 表示最后(last简写),只能用在dayOfMonth和dayOfWeek两个域,用在dayOfMonth域(前面不需要加数字)表示一个月的最后一天,用在dayOfWeek域,如果前面没有数字,表示7(星期六),如果前面有数字,表示一个月的最后一个星期几。比如6L,表示一个月的最后一个星期五。
W 表示当月(最近寻找不会跨过月份)离指定日期最近的那个工作日(weekday简写),只能用在dayOfMonth域。比如6W,如果6号是星期六,则最近的工作日为5号(即星期五),如果6号是星期日,则最近的工作日为7号(即下个星期一),否则就表示6号本身。再比如31W,如果31W是星期六或星期日,则最近的工作日都是之前的星期五,不会跨月份。
LW 一个月的最后一个工作日。
# 表示一个月中第几个星期几,前面的数字表示星期几,后面的数字表示第几个,只能用在dayOfWeek域,比如7#2,表示一个月中第二个星期六。
C 这个字符楼主实在没搞清楚是干啥的,基本也很少用到,就没去深究了。
0 0 0 1 * ? 每个月1号凌晨零点整 * 0/5 * * * ? 每5分钟触发一次 0 30 7 * * ? 每天早上七点半 0 30 7 * * 2-6 工作日(周一到周五)早上七点半 0 0 8 L * ? 每个月最后一天早上八点整 0 0 8 L-1 * ? 每个月倒数第二天早上八点整 0 0 8 LW * ? 每个月最后一个工作日早上八点整 0 0/30 9-17 * * ? 朝九晚五每半小时触发 0 0/5 14%2c18 * * ? 每天下午2:00~2:55和6:00~6:55之间每5分钟触发一次 0 0 8 ? * 6#3 每个月第三个星期五早上八点整 0 0 8 ? * 6L 每个月最后一个星期五早上八点整
由于月份和星期域可以用英文简称代替,楼主为了方便使用,收集整理了月份与星期的简写,如下
一月 January Jan 二月 February Feb 三月 March Mar 四月 April Apr 五月 May May 六月 June Jun 七月 July Jul 八月 August Aug 九月 Septemper Sep 十月 October Oct 十一月 November Nov 十二月 December Dec 星期一 Monday Mon 星期二 Tuesday Tue 星期三 Wednesday Wed 星期四 Thursday Thu 星期五 Friday Fri 星期六 Saturday Sat 星期日 Sun Sun
通过完成TL给的这个需求,楼主对cron表达式有了一个深入的了解,感觉还蛮有成就感的,心中更是暗暗窃喜,今年的绩效栏又可以多加一笔了。当然,作为一名码农,最重要的还是要不断地尝试,只有多练、多看、多学、多想,编程才能更进一步。
俄乌冲突进入第 3 周,一些非常规行为者继续针对俄罗斯国家支持的企业发起攻击,进行一连串的黑客攻击和数据泄露。而由俄罗斯国家控制的石油管道巨头 Transneft 无疑成为了重点攻击对象。 本周四,泄密托管网站 Distributed Denial of Secrets 发布了一个 79GB 的电子...
因担心俄乌冲突引发的近期针对欧洲卫星网络发起的攻击可能很快蔓延到美国本土,政府机构已经向卫星通信网络运营商发出了“潜在威胁”预警。在美国网络安全与基础设施安全局(CISA)和联邦调查局(FBI)本周联合发布的一份公告中,其敦促卫星通讯(SATCOM)网络提供商和基础设施组织加强安全防御。若被入侵,或...
黑莓威胁情报(BlackBerry Threat Intelligence)团队刚刚发出警报 —— 一款自 2021 年 8 月存续至今的 LokiLocker 勒索软件,正在互联网上传播肆虐。据悉,该恶意软件采用了 AES + RSA 的加密方案,若用户拒绝在指定期限内支付赎金,它就会擦除其 PC...
一家欧洲隐私监督机构已经制裁了有争议的面部识别公司Clearview AI,该公司从互联网上搜刮自拍,积累了约100亿张脸的数据库,为其出售给执法部门的身份匹配服务。意大利的数据保护机构今天宣布对Clearview AI违反欧盟法律的行为处以2000万欧元罚款。 同时命令这家有争议的公司删除其...
近期,网络安全公司Binarly研究人员发现16个影响惠普企业设备的统一可扩展固件接口高危漏洞。攻击者可以利用这些漏洞植入固件,使其能够在操作系统更新后继续存在并绕过 UEFI安全启动、Intel Boot Guard和基于虚拟化的安全性。受影响的设备包括多个惠普企业设备,如笔记本电脑、...
微软今天宣布近日捣毁了一个名为 ZLoader 的主要犯罪僵尸网络,这也是使用 XLM 宏作为攻击面的僵尸网络之一。微软的最新行动包括技术和法律活动,以破坏利用 ZLoader 作为恶意软件即服务(malware-as-a-service)的犯罪集团的运作。 在本次捣毁行动中,微软还锁定了一位开发...