Лимит ресурсов для развертывания в Kubernetes - PullRequest
2 голосов
/ 14 мая 2019

Вот мой файл развертывания и обслуживания для Django. 3 модуля, сгенерированные из deploy.yaml, работают, но запрос ресурсов и ограничения игнорируются.

Я видел много руководств по применению спецификаций ресурсов на модулях, но не на файлах развертывания, есть ли способ обойти это?

Вот мой файл yaml:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    app: djangoapi
    type: web
  name: djangoapi
  namespace: "default"
spec:
  replicas: 3
  template:
    metadata:
      labels:
        app: djangoapi
        type: web
    spec:
      containers:
      - name: djangoapi
        image: wbivan/app:v0.8.1a
        imagePullPolicy: Always
        args:
        - gunicorn
        - api.wsgi
        - --bind
        - 0.0.0.0:8000
        resources:
          requests:
            memory: "64Mi"
            cpu: "250m"
          limits:
            memory: "128Mi"
            cpu: "500m"
        envFrom:
        - configMapRef:
            name: djangoapi-config
        ports:
        - containerPort: 8000
        resources: {}
      imagePullSecrets:
        - name: regcred
      restartPolicy: Always

---
apiVersion: v1
kind: Service
metadata:
  name: djangoapi-svc
  namespace: "default"
  labels:
    app: djangoapi
spec:
  ports:
  - port: 8000
    protocol: TCP
    targetPort: 8000
  selector:
    app: djangoapi
    type: web
  type: NodePort  

Ответы [ 2 ]

2 голосов
/ 14 мая 2019

Существует один дополнительный атрибут ресурса в определении вашего контейнера после портов.

resources: {}

Это переопределяет исходное определение ресурса. Удалите этот и примените его снова.

0 голосов
/ 22 мая 2019

Простой способ избежать такой проблемы - использовать валидатор YAML.

yamllint Похоже, отличный инструмент для проверки и анализа YAML.

После того, как вы запустите проверку, она предоставит список всех неправильных действий, которые вы делали.

Пример: -

    # yamllint file.yml
38:9      error    duplication of key "resources" in mapping  (key-duplicates)
...