首页 > 解决方案 > Kubernetes 部署资源限制

问题描述

这是我的 Django 部署和服务文件。从 deployment.yaml 生成的 3 个 pod 可以工作,但是资源请求和限制被忽略了。

我看过很多关于在 Pod 上应用资源规范而不是在部署文件上应用资源规范的教程,有没有办法解决它?

这是我的 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  

标签: amazon-web-serviceskubernetesresources

解决方案


在端口之后,您的容器定义下还有一个额外的资源属性。

resources: {}

这会覆盖原始资源定义。删除这个并再次应用它。


推荐阅读