Скопируйте файл из модуля cron в локальный каталог в AKS - PullRequest
0 голосов
/ 20 февраля 2019

Я создал задание cron, которое запускается каждые 60 минут.В контейнере задания я смонтировал том emptyDir в виде подробных логов.В моем контейнере я пишу CSV-файл по пути detailed-logs\logs.csv.

Я пытаюсь скопировать этот файл из модуля pod на локальный компьютер, используя kubectl cp podname:detailed-logs\logs.csv \k8slogs\logs.csv, но выдает ошибку:

путь "подробные журналы \ logs.csv" не найден (Данный файл или каталог отсутствует).

После успешного выполнения задания модуль, созданный заданием, переходит в состояние completed. Может ли это быть проблемой?

1 Ответ

0 голосов
/ 21 февраля 2019

Файл, на который вы ссылаетесь, не будет сохраняться после завершения работы вашего модуля.Что вы можете сделать, это сделать резервную копию файла, когда выполняется задание cron.Два решения, которые я могу предложить, это либо прикрепить постоянный том к модулю задания, либо загрузить файл куда-нибудь во время выполнения задания.

ИСПОЛЬЗОВАТЬ УСТОЙЧИВЫЙ ОБЪЕМ

Здесь вы можете создать PV с помощью быстрой readWriteOnce Заявки на постоянный объем:

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: my-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 5Gi

Затем вы можете установить его на модуль, используя следующее:

      ...
        volumeMounts:
        - name: persistent-storage
          mountPath: /detailed-logs
      volumes:
      - name: persistent-storage
        persistentVolumeClaim:
          claimName: my-pvc
      ...

ЗАГРУЗИТЬФАЙЛ

То, как я это делаю, - это запуск задания в контейнере с установленным aws-cli, а затем сохранение моего файла на AWS S3, вы можете выбрать другую платформу:

apiVersion: v1
kind: ConfigMap
metadata:
  name: backup-sh
data:
  backup.sh: |-
    #!/bin/bash
    aws s3 cp /myText.txt s3://bucketName/
---
apiVersion: batch/v1beta1
kind: CronJob
metadata:
  name: s3-backup
spec:
  schedule: "0 0 * * *"
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: aws-kubectl
            image: expert360/kubectl-awscli:v1.11.2
            env:
            - name: AWS_ACCESS_KEY_ID
              valueFrom:
                secretKeyRef:
                  name: s3-creds
                  key: access-key-id
            - name: AWS_SECRET_ACCESS_KEY
              valueFrom:
                secretKeyRef:
                  name: s3-creds
                  key: secret-access-key
            command:
              - /bin/sh
              - -c
            args: ["sh /backup.sh"]
            volumeMounts:
            - name: backup-sh
              mountPath: /backup.sh
              readOnly: true
              subPath: backup.sh
          volumes:
          - name: backup-sh
            configMap:
              name: backup-sh
          restartPolicy: Never
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...