yurake/k8s-3tier-webapp

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

Summary

Maintainability
Test Coverage
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: cassandra
  labels:
    app: cassandra
spec:
  serviceName: cassandra
  replicas: 1
  selector:
    matchLabels:
      app: cassandra
  template:
    metadata:
      labels:
        tier: backend
        component: database
        app: cassandra
    spec:
      terminationGracePeriodSeconds: 1800
      containers:
        - name: cassandra
          image: yurak/cassandra:latest
          imagePullPolicy: Always
          ports:
            - containerPort: 7000
              name: intra-node
            - containerPort: 7001
              name: tls-intra-node
            - containerPort: 7199
              name: jmx
            - containerPort: 9042
              name: cql
          lifecycle:
            preStop:
              exec:
                command:
                  - /bin/sh
                  - -c
                  - nodetool drain
          env:
            - name: MAX_HEAP_SIZE
              value: 512M
            - name: HEAP_NEWSIZE
              value: 100M
            - name: CASSANDRA_SEEDS
              value: "cassandra-0.cassandra.default.svc.cluster.local"
            - name: CASSANDRA_CLUSTER_NAME
              value: "webapp-cluster"
            - name: CASSANDRA_DC
              value: "webapp-datacenter"
            - name: CASSANDRA_RACK
              value: "webapp-rack"
            - name: CASSANDRA_ENDPOINT_SNITCH
              value: "GossipingPropertyFileSnitch"
            - name: CASSANDRA_KEYSPACE
              value: "webapp"
          livenessProbe:
            tcpSocket:
              port: 9042
          readinessProbe:
            exec:
              command:
                - /opt/cassandra/bin/cqlsh
                - -u
                - cassandra
                - -p
                - cassandra
                - -e
                - describe keyspace webapp
            initialDelaySeconds: 15
            timeoutSeconds: 5
          volumeMounts:
            - name: cassandra-persistent-storage
              mountPath: /var/lib/cassandra
      volumes:
        - name: cassandra-persistent-storage
          persistentVolumeClaim:
            claimName: cassandra-pvc