109 lines
2.3 KiB
YAML
109 lines
2.3 KiB
YAML
---
|
|
apiVersion: apps/v1
|
|
kind: StatefulSet
|
|
metadata:
|
|
name: mongo
|
|
annotations:
|
|
keel.sh/policy: force
|
|
keel.sh/trigger: poll
|
|
keel.sh/pollSchedule: "@midnight"
|
|
spec:
|
|
revisionHistoryLimit: 0
|
|
serviceName: mongo
|
|
selector:
|
|
matchLabels:
|
|
app: mongo
|
|
replicas: 1
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: mongo
|
|
spec:
|
|
securityContext:
|
|
fsGroup: 999
|
|
containers:
|
|
- name: mongo
|
|
image: mongo:5
|
|
command:
|
|
- mongod
|
|
- --quiet
|
|
- --replSet
|
|
- rs0
|
|
- --bind_ip_all
|
|
ports:
|
|
- name: mongo
|
|
containerPort: 27017
|
|
securityContext:
|
|
readOnlyRootFilesystem: true
|
|
runAsNonRoot: true
|
|
runAsUser: 999
|
|
volumeMounts:
|
|
- name: tmp
|
|
mountPath: /tmp
|
|
- name: mongo-data
|
|
mountPath: /data/db
|
|
- name: exporter
|
|
image: percona/mongodb_exporter:0.30.0
|
|
args:
|
|
- --compatible-mode
|
|
- --mongodb.direct-connect=false
|
|
ports:
|
|
- name: mongo-exporter
|
|
containerPort: 9216
|
|
securityContext:
|
|
readOnlyRootFilesystem: true
|
|
runAsNonRoot: true
|
|
runAsUser: 65535
|
|
env:
|
|
- name: MONGODB_URI
|
|
value: mongodb://mongo
|
|
# Make sure MongoDB instances run on storage{1..3} nodes, as close
|
|
# as possible to Longhorn instances
|
|
tolerations:
|
|
- key: dedicated
|
|
operator: Equal
|
|
value: storage
|
|
effect: NoSchedule
|
|
nodeSelector:
|
|
dedicated: storage
|
|
volumes:
|
|
- name: tmp
|
|
emptyDir: {}
|
|
volumeClaimTemplates:
|
|
- metadata:
|
|
name: mongo-data
|
|
spec:
|
|
storageClassName: longhorn
|
|
accessModes:
|
|
- ReadWriteOnce
|
|
resources:
|
|
requests:
|
|
storage: 10Gi
|
|
---
|
|
apiVersion: v1
|
|
kind: Service
|
|
metadata:
|
|
name: mongo-exporter
|
|
annotations:
|
|
prometheus.io/scrape: 'true'
|
|
spec:
|
|
ports:
|
|
- protocol: TCP
|
|
port: 9216
|
|
selector:
|
|
app: mongo
|
|
---
|
|
apiVersion: batch/v1
|
|
kind: Job
|
|
metadata:
|
|
name: mongo-rs0-init
|
|
spec:
|
|
template:
|
|
spec:
|
|
containers:
|
|
- name: mongo-rs0-init
|
|
image: mongo
|
|
command: ["mongo", "--eval", "rs.initiate();", "mongodb://mongo-0.mongo"]
|
|
restartPolicy: OnFailure
|
|
backoffLimit: 4
|