apiVersion: apps/v1 kind: Deployment metadata: name: dataroom-service namespace: the-order labels: app: dataroom-service version: v1 spec: replicas: 2 selector: matchLabels: app: dataroom-service template: metadata: labels: app: dataroom-service version: v1 spec: containers: - name: dataroom image: theorder/dataroom-service:latest ports: - containerPort: 4004 name: http env: - name: PORT value: "4004" - name: NODE_ENV valueFrom: configMapKeyRef: name: the-order-config key: ENVIRONMENT - name: DATABASE_URL valueFrom: secretKeyRef: name: the-order-secrets key: database-url - name: STORAGE_BUCKET valueFrom: secretKeyRef: name: the-order-secrets key: storage-bucket resources: requests: memory: "256Mi" cpu: "100m" limits: memory: "512Mi" cpu: "500m" livenessProbe: httpGet: path: /health port: 4004 initialDelaySeconds: 30 periodSeconds: 10 timeoutSeconds: 5 failureThreshold: 3 readinessProbe: httpGet: path: /health port: 4004 initialDelaySeconds: 10 periodSeconds: 5 timeoutSeconds: 3 failureThreshold: 3 startupProbe: httpGet: path: /health port: 4004 initialDelaySeconds: 0 periodSeconds: 10 timeoutSeconds: 3 failureThreshold: 30 lifecycle: preStop: exec: command: ["/bin/sh", "-c", "sleep 15"] --- apiVersion: v1 kind: Service metadata: name: dataroom-service namespace: the-order spec: selector: app: dataroom-service ports: - port: 80 targetPort: 4004 protocol: TCP type: ClusterIP --- apiVersion: autoscaling/v2 kind: HorizontalPodAutoscaler metadata: name: dataroom-service-hpa namespace: the-order spec: scaleTargetRef: apiVersion: apps/v1 kind: Deployment name: dataroom-service minReplicas: 2 maxReplicas: 10 metrics: - type: Resource resource: name: cpu target: type: Utilization averageUtilization: 70 - type: Resource resource: name: memory target: type: Utilization averageUtilization: 80