apiVersion: apps/v1 kind: Deployment metadata: name: {{ .Release.Name }} spec: selector: matchLabels: app.kubernetes.io/name: {{ .Release.Name }} strategy: type: Recreate template: metadata: labels: app.kubernetes.io/name: {{ .Release.Name }} spec: containers: - name: nginx image: {{ .Values.image }} imagePullPolicy: Always ports: - containerPort: 80 name: http resources: requests: memory: "1Gi" cpu: "1m" limits: memory: "1Gi" cpu: "1" --- apiVersion: v1 kind: Service metadata: name: {{ .Release.Name }} spec: type: ClusterIP selector: app.kubernetes.io/name: {{ .Release.Name }} ports: - name: http protocol: TCP port: 80 targetPort: http --- apiVersion: networking.k8s.io/v1 kind: Ingress metadata: name: {{ .Release.Name }} annotations: cert-manager.io/cluster-issuer: letsencrypt nginx.ingress.kubernetes.io/proxy-body-size: "0" nginx.org/client-max-body-size: "0" spec: ingressClassName: nginx rules: - host: {{ .Values.domain }} http: paths: - path: / pathType: Prefix backend: service: name: {{ .Release.Name }} port: name: http tls: - hosts: - {{ .Values.domain }} secretName: {{ .Release.Name }}-tls-cert