5

我们在 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

4

3 回答 3

4

我会这样做:

kubectl delete po $(kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep eventstore) -n $NAMESPACE

或(你的方式)

kubectl get pods -n $NAMESPACE -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' | grep eventstore | xargs -n 1 -I {} kubectl delete po {}

现在,如果您知道要删除 pod "eventstore-0",为什么不直接删除kubectl delete pod eventstore-0呢?

于 2018-06-01T10:57:00.933 回答
1

我建议使用标签选择器来过滤结果kubectl get,并使用 jsonpath 输出来获取 pod 的名称。

假设您的 pod 带有标签,app=eventstore并且您想要删除带有此标签的每个 pod,您可以使用以下命令:

k get po --namespace=$NAMESPACE --selector app=eventstore -o jsonpath="{.items[*].metadata.name}" | xargs -n 1 -I {} kubectl --namespace=$NAMESPACE delete po {}

如果您只想删除第一个 pod,请使用jsonpath="{.items[0].metadata.name}"

于 2018-06-01T10:48:46.067 回答
0

@suren 的回答很好,但是当您想删除多个特定的pod 时,它并不适用于所有情况。例如,如果您有:pod1、pod2、pod3、pod4,并且您只想删除 pod2 和 pod4,则无法使用 grep 执行此操作(grep pod将捕获所有这些)。

在这种情况下,您可以像这样删除它们:

kubectl delete pods -n $NAMESPACE $(echo -e 'pod2\npod4')
于 2021-07-17T04:20:39.470 回答