apiVersion: apps/v1 kind: Deployment metadata: labels: {{- include "longhorn.labels" . | nindent 4 }} app: longhorn-ui name: longhorn-ui namespace: {{ include "release_namespace" . }} spec: replicas: 1 selector: matchLabels: app: longhorn-ui template: metadata: labels: {{- include "longhorn.labels" . | nindent 8 }} app: longhorn-ui spec: containers: - name: longhorn-ui image: {{ template "registry_url" . }}{{ .Values.image.longhorn.ui.repository }}:{{ .Values.image.longhorn.ui.tag }} imagePullPolicy: IfNotPresent volumeMounts: - name : nginx-cache mountPath: /var/cache/nginx/ - name : nginx-config mountPath: /var/config/nginx/ - name: var-run mountPath: /var/run/ ports: - containerPort: 8000 name: http env: - name: LONGHORN_MANAGER_IP value: "http://longhorn-backend:9500" volumes: - emptyDir: {} name: nginx-cache - emptyDir: {} name: nginx-config - emptyDir: {} name: var-run {{- if .Values.privateRegistry.registrySecret }} imagePullSecrets: - name: {{ .Values.privateRegistry.registrySecret }} {{- end }} {{- if .Values.longhornUI.priorityClass }} priorityClassName: {{ .Values.longhornUI.priorityClass | quote}} {{- end }} {{- if .Values.longhornUI.tolerations }} tolerations: {{ toYaml .Values.longhornUI.tolerations | indent 6 }} {{- end }} {{- if .Values.longhornUI.nodeSelector }} nodeSelector: {{ toYaml .Values.longhornUI.nodeSelector | indent 8 }} {{- end }} --- kind: Service apiVersion: v1 metadata: labels: {{- include "longhorn.labels" . | nindent 4 }} app: longhorn-ui {{- if eq .Values.service.ui.type "Rancher-Proxy" }} kubernetes.io/cluster-service: "true" {{- end }} name: longhorn-frontend namespace: {{ include "release_namespace" . }} spec: {{- if eq .Values.service.ui.type "Rancher-Proxy" }} type: ClusterIP {{- else }} type: {{ .Values.service.ui.type }} {{- end }} selector: app: longhorn-ui ports: - name: http port: 80 targetPort: http {{- if .Values.service.ui.nodePort }} nodePort: {{ .Values.service.ui.nodePort }} {{- else }} nodePort: null {{- end }}