blob: 6874355375389694e4796b59b455ed3ec5008ab8 [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: {{.Name}}
namespace: {{.Namespace}}
labels:
{{range $k,$v := .Labels }}
{{$k}}: {{$v}}
{{end}}
annotations:
{{range $k,$v := .Cluster.Spec.Annotations }}
{{$k}}: {{$v}}
{{end}}
spec:
replicas: 1
selector:
matchLabels:
{{range $k,$v := .Selector }}
{{$k}}: {{$v}}
{{end}}
updateStrategy:
type: RollingUpdate
podManagementPolicy: Parallel
template:
metadata:
labels:
{{range $k,$v := .Labels }}
{{$k}}: {{$v}}
{{end}}
annotations:
{{range $k,$v := .Cluster.Spec.Annotations }}
{{$k}}: {{$v}}
{{end}}
spec:
terminationGracePeriodSeconds: 30
nodeSelector:
{{range $k,$v := .Cluster.Spec.NodeSelector }}
{{$k}}: {{$v}}
{{end}}
containers:
- name: scheduler
args:
- scheduler
image: {{.Cluster.Spec.Scheduler.Image}}:{{.Cluster.Spec.Scheduler.Version}}
imagePullPolicy: IfNotPresent
volumeMounts:
- mountPath: /usr/local/airflow/dags/
name: dags-data
- name: metrics
image: pbweb/airflow-prometheus-exporter:latest
imagePullPolicy: IfNotPresent
ports:
- containerPort: 9112
name: metrics
volumes:
- emptyDir: {}
name: dags-data