yurake/k8s-3tier-webapp

View on GitHub
kubernetes/hazelcast/hazelcast-statefulset.yaml

Summary

Maintainability
Test Coverage
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: hazelcast
  labels:
    app: hazelcast
spec:
  replicas: 1
  serviceName: hazelcast
  selector:
    matchLabels:
      app: hazelcast
  template:
    metadata:
      labels:
        tier: backend
        component: cache
        app: hazelcast
    spec:
      containers:
        - name: hazelcast
          image: hazelcast/hazelcast:5.5.0
          imagePullPolicy: Always
          livenessProbe:
            httpGet:
              path: /hazelcast/health/node-state
              port: 5701
            initialDelaySeconds: 30
            periodSeconds: 10
            timeoutSeconds: 10
            successThreshold: 1
            failureThreshold: 10
          readinessProbe:
            httpGet:
              path: /hazelcast/health/node-state
              port: 5701
            initialDelaySeconds: 30
            periodSeconds: 10
            timeoutSeconds: 10
            successThreshold: 1
            failureThreshold: 10
          ports:
            - containerPort: 5701
            - containerPort: 8080
          env:
            - name: PROMETHEUS_PORT
              valueFrom:
                configMapKeyRef:
                  name: hazelcast-configmap
                  key: prometheus-port
            - name: JAVA_OPTS
              valueFrom:
                configMapKeyRef:
                  name: hazelcast-configmap
                  key: java-ops
            - name: LOGGING_LEVEL
              valueFrom:
                configMapKeyRef:
                  name: hazelcast-configmap
                  key: logging-level
          volumeMounts:
            - name: hazelcast-storage
              mountPath: /data/hazelcast
      volumes:
        - name: hazelcast-storage
          configMap:
            name: hazelcast-configmap