kubernetes - 手动触发的 cron 作业可以遵守 concurrencyPolicy 吗?
问题描述
所以我有这样的 cron 工作:
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: my-cron-job
spec:
schedule: "0 0 31 2 *"
failedJobsHistoryLimit: 3
successfulJobsHistoryLimit: 1
concurrencyPolicy: "Forbid"
startingDeadlineSeconds: 30
jobTemplate:
spec:
backoffLimit: 0
activeDeadlineSeconds: 120
...
然后我像这样手动触发作业:
kubectl create job my-job --namespace precompile --from=cronjob/my-cron-job
但它似乎我可以随心所欲地触发工作并且concurrencyPolicy: "Forbid"
被忽略。
有没有办法让手动触发的作业尊重这一点,还是我必须手动检查?
解决方案
请注意,并发策略仅适用于由同一 cron 作业创建的作业。
该concurrencyPolicy
字段仅适用于由相同 cron 作业创建的作业,如文档中所述:https ://kubernetes.io/docs/tasks/job/automated-tasks-with-cron-jobs/#concurrency-policy
执行时$ kubectl create job my-job --namespace precompile --from=cronjob/my-cron-job
,您实际上是在自己创建一个一次性作业,该作业使用该spec.jobTemplate
字段作为创建它的参考。由于concurrencyPolicy
是一个 cronjob 字段,它甚至没有被评估。
TL;博士
这实际上是预期的行为。手动创建的工作不受concurrencyPolicy
. 没有可以传递的标志来更改此行为。
推荐阅读
- mysql - 如何将 MySQL 数据库迁移到 SAP HANA
- github - Github Pages 使用 Symlink 构建失败
- javascript - 在 array[1].value = array[2].key 的情况下获取比较数组 [2] 的值
- python - 在 Scikit-learn 中使用 Smote 和 Gridsearchcv
- python - 现在在时间间隔内更改 BooleanField 值
- javascript - onClick 功能不起作用
- c# - 如何在连接到本地网络的设备上访问您的 API 并在 C# 中调试代码
- c++ - 如何在 Visual Studio(C++11) 中处理相互依赖/循环依赖
- java - 端口无效。退出... org.openqa.selenium.os.OsProcess checkForError 同时使用 selenium 启动 chrome
- azure - 如何在 Azure Devops (VSTS) 中导入发布定义?