Kubernetes任务调用Job与CronJob及源码分析( 四 )
在syncOne维护了cronJob的Active列表 , 在遍历cronJob对应的job列表的时候会判断该job是不是应该从Active列表中删除 , 操作完之后会更新cronJob的状态 。
然后会查看当前的cronJob是否已被删除、是否处于suspend状态、判断是否最近有job被调度 , 并获取最后一次调度时间判断是否满足StartingDeadlineSeconds条件等 。
接下来会根据ConcurrencyPolicy来判断是Forbid还是Replace 。 如果是Forbid那么直接略过此次调度 , 如果是Replace那么会删除所有的Active列表,等后面重新创建 。
最后调用CreateJob创建job 。
总结【Kubernetes任务调用Job与CronJob及源码分析】这篇文章我们首先介绍了Job和CronJob的具体使用方法 , 以及其中需要注意的参数配置 , 然后通过源码来解释相应的配置会产生什么样的结果 。 例如job来说 , 如果我们设置的completions小于parallelism , 那么在实际运行的时候实际完成的pod数量是可能超过completions的等等 。 通过源码我们对job以及cronjob也有了一个更好的理解 。
- 在kubernetes中部署企业级ELK并使用其APM
- kubernetes-Prometheus基于邮件告警
- 软网推荐:右键调用 多重更名更方便
- MIUI很出色,唯一不满意的地方就是:多任务,打开慢
- 一个Postman小技巧:利用脚本赋值中间变量,实现两步调用
- 大规模分布式强化学习基础架构Menger, 大幅提高真实任务的学习效率
- Python调用时使用*和**
- go-zero 如何应对海量定时/延迟任务?
- Java|Java:调用参数p的printPhone方法
- 月球|我国航天史上难度最高的任务即将实施,看嫦五如何将月壤送回地球