statefulset.yaml 3.18 KB
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: postgresql
  namespace: ecommerce
spec:
  serviceName: postgresql-service
  replicas: 1
  selector:
    matchLabels:
      app: postgresql
  template:
    metadata:
      labels:
        app: postgresql
    spec:
      # 添加初始化容器来创建额外的数据库
      initContainers:
      - name: init-databases
        image: postgres:15
        command:
        - /bin/sh
        - -c
        - |
          set -e
          echo "Waiting for PostgreSQL to be ready..."
          until pg_isready -h localhost -U admin; do
            sleep 2
          done
          echo "PostgreSQL is ready. Creating additional databases..."
          
          # 创建 notification service 数据库 - 使用 IF NOT EXISTS
          psql -U admin -d postgres -c "CREATE DATABASE IF NOT EXISTS ecommerce_notifications;"
          echo "Database ecommerce_notifications ensured"
          
          # 可以在这里添加其他微服务的数据库 - 都使用 IF NOT EXISTS
          # psql -U admin -d postgres -c "CREATE DATABASE IF NOT EXISTS ecommerce_users;"
          # echo "Database ecommerce_users ensured"
          # psql -U admin -d postgres -c "CREATE DATABASE IF NOT EXISTS ecommerce_orders;"
          # echo "Database ecommerce_orders ensured"
          # psql -U admin -d postgres -c "CREATE DATABASE IF NOT EXISTS ecommerce_products;"
          # echo "Database ecommerce_products ensured"
          
          echo "All additional databases created/ensured successfully"
        env:
        - name: PGPASSWORD
          valueFrom:
            secretKeyRef:
              name: postgresql-secret
              key: password
        volumeMounts:
        - name: postgresql-data
          mountPath: /var/lib/postgresql/data
      containers:
        - name: postgresql
          image: postgres:15
          ports:
            - containerPort: 5432
          env:
            - name: POSTGRES_DB
              value: "ecommerce"
            - name: POSTGRES_USER
              value: "admin"
            - name: POSTGRES_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: postgresql-secret
                  key: password
            - name: PGDATA
              value: /var/lib/postgresql/data/pgdata
          volumeMounts:
            - name: postgresql-data
              mountPath: /var/lib/postgresql/data
          livenessProbe:
            exec:
              command:
                - pg_isready
                - -U
                - admin
            initialDelaySeconds: 60
            periodSeconds: 20
            timeoutSeconds: 10
            failureThreshold: 3
          readinessProbe:
            exec:
              command:
                - pg_isready
                - -U
                - admin
            initialDelaySeconds: 30
            periodSeconds: 10
            timeoutSeconds: 5
            failureThreshold: 3
          resources:
            requests:
              memory: "256Mi"
              cpu: "250m"
            limits:
              memory: "512Mi"
              cpu: "500m"
      volumes:
        - name: postgresql-data
          persistentVolumeClaim:
            claimName: postgresql-pvc