我们在 gcloud 上使用 >1.8 版本的 k8s。不幸的是,EventStore 会停止推送数据,直到重新启动。因此,我们希望kubectl --namespace=$NAMESPACE delete pod eventstore-0
每 6 小时运行一次。因此,我们有一个 cron 工作,例如:
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: eventstore-restart
spec:
# Run every full hour, 15 past, 30 past, 45 past every other time-unit.
schedule: "0,15,30,45 * * * *"
concurrencyPolicy: Forbid
successfulJobsHistoryLimit: 1
failedJobsHistoryLimit: 5
jobTemplate:
spec:
template:
spec:
containers:
- name: eventstore-restart
image: eu.gcr.io/$PROJECT_ID/kubectl:latest
imagePullPolicy: Always
command: [ "/bin/sh", "-c" ]
args:
- 'set -x; kubectl --namespace=$NAMESPACE get pods
| grep -ho "eventstore-\d+"
| xargs -n 1 -I {} kubectl --namespace=$NAMESPACE delete pod {}'
env:
- name: NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
restartPolicy: OnFailure
serviceAccount: restart-eventstore
但是,这似乎扩展为kubectl get pods ...
,通过管道传输| { ... }
,这导致"/bin/sh: syntax error: unexpected end of file (expecting "}")
脚本失败。
如何编写命令以按计划删除 pod?