88 lines
2.8 KiB
YAML
88 lines
2.8 KiB
YAML
|
{{- if .Values.async }}
|
||
|
apiVersion: apps/v1
|
||
|
kind: Deployment
|
||
|
metadata:
|
||
|
labels:
|
||
|
app: {{ template "openfaas.name" . }}
|
||
|
chart: {{ .Chart.Name }}-{{ .Chart.Version }}
|
||
|
component: queue-worker
|
||
|
heritage: {{ .Release.Service }}
|
||
|
release: {{ .Release.Name }}
|
||
|
name: queue-worker
|
||
|
namespace: {{ .Release.Namespace | quote }}
|
||
|
spec:
|
||
|
replicas: {{ .Values.queueWorker.replicas }}
|
||
|
selector:
|
||
|
matchLabels:
|
||
|
app: queue-worker
|
||
|
template:
|
||
|
metadata:
|
||
|
annotations:
|
||
|
prometheus.io.scrape: "false"
|
||
|
labels:
|
||
|
app: queue-worker
|
||
|
spec:
|
||
|
{{- if .Values.basic_auth }}
|
||
|
volumes:
|
||
|
- name: auth
|
||
|
secret:
|
||
|
secretName: basic-auth
|
||
|
{{- end }}
|
||
|
containers:
|
||
|
- name: queue-worker
|
||
|
resources:
|
||
|
{{- .Values.queueWorker.resources | toYaml | nindent 12 }}
|
||
|
image: {{ .Values.queueWorker.image }}
|
||
|
imagePullPolicy: {{ .Values.openfaasImagePullPolicy }}
|
||
|
env:
|
||
|
{{- if .Values.nats.external.enabled }}
|
||
|
- name: faas_nats_address
|
||
|
value: "{{ .Values.nats.external.host }}"
|
||
|
- name: faas_nats_port
|
||
|
value: "{{ .Values.nats.external.port }}"
|
||
|
- name: faas_nats_cluster_name
|
||
|
value: "{{ .Values.nats.external.clusterName }}"
|
||
|
{{- else }}
|
||
|
- name: faas_nats_address
|
||
|
value: "nats.{{ .Release.Namespace }}.svc.{{ .Values.kubernetesDNSDomain }}"
|
||
|
{{- end}}
|
||
|
- name: faas_nats_channel
|
||
|
value: "{{ .Values.nats.channel }}"
|
||
|
- name: faas_nats_queue_group
|
||
|
value: "{{ .Values.queueWorker.queueGroup }}"
|
||
|
- name: faas_gateway_address
|
||
|
value: "gateway.{{ .Release.Namespace }}.svc.{{ .Values.kubernetesDNSDomain }}"
|
||
|
- name: "gateway_invoke"
|
||
|
value: "{{ .Values.queueWorker.gatewayInvoke }}"
|
||
|
{{- if .Values.functionNamespace }}
|
||
|
- name: faas_function_suffix
|
||
|
value: ".{{ .Values.functionNamespace }}.svc.{{ .Values.kubernetesDNSDomain }}"
|
||
|
{{- end }}
|
||
|
- name: max_inflight
|
||
|
value: "{{ .Values.queueWorker.maxInflight }}"
|
||
|
- name: ack_wait # Max duration of any async task / request
|
||
|
value: {{ .Values.queueWorker.ackWait }}
|
||
|
{{- if .Values.basic_auth }}
|
||
|
- name: secret_mount_path
|
||
|
value: "/var/secrets"
|
||
|
- name: basic_auth
|
||
|
value: "{{ .Values.basic_auth }}"
|
||
|
volumeMounts:
|
||
|
- name: auth
|
||
|
readOnly: true
|
||
|
mountPath: "/var/secrets"
|
||
|
{{- end }}
|
||
|
{{- with .Values.nodeSelector }}
|
||
|
nodeSelector:
|
||
|
{{ toYaml . | indent 8 }}
|
||
|
{{- end }}
|
||
|
{{- with .Values.affinity }}
|
||
|
affinity:
|
||
|
{{ toYaml . | indent 8 }}
|
||
|
{{- end }}
|
||
|
{{- with .Values.tolerations }}
|
||
|
tolerations:
|
||
|
{{ toYaml . | indent 8 }}
|
||
|
{{- end }}
|
||
|
{{- end }}
|