CodexBloom - Programming Q&A Platform

Kubernetes Pod implementing in ContainerCreating State After Deployment with StatefulSet and Volume Mount

👀 Views: 178 💬 Answers: 1 📅 Created: 2025-07-24
kubernetes statefulset pvc YAML

I'm relatively new to this, so bear with me. I'm relatively new to this, so bear with me... I'm working with an scenario where my Kubernetes pod is exploring in the `ContainerCreating` state after I deployed a StatefulSet. I’m using Kubernetes version 1.24 and trying to create a StatefulSet with a persistent volume claim (PVC) that should be dynamically provisioned using the default StorageClass. The YAML configuration for my StatefulSet looks like this: ```yaml apiVersion: apps/v1 kind: StatefulSet metadata: name: my-statefulset spec: serviceName: "my-service" replicas: 3 selector: matchLabels: app: my-app template: metadata: labels: app: my-app spec: containers: - name: my-container image: my-image:latest ports: - containerPort: 80 volumeMounts: - name: my-data mountPath: /data volumeClaimTemplates: - metadata: name: my-data spec: accessModes: ["ReadWriteOnce"] resources: requests: storage: 10Gi ``` After applying this configuration with `kubectl apply -f my-statefulset.yaml`, I can see the pods are created, but they remain in the `ContainerCreating` state. When I run `kubectl describe pod <pod-name>`, I get the following message: ``` Warning FailedScheduling 5s (x3 over 10s) default-scheduler 0/3 nodes are available: 1 Insufficient cpu, 1 node(s) had unbound immediate PersistentVolumeClaims. ``` I’ve checked the StorageClass and it looks fine: ```yaml apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: standard provisioner: kubernetes.io/gce-pd parameters: type: pd-standard replication-type: none ``` The scenario seems to point to the PVC not being bound, but I’ve confirmed that the StorageClass is properly set. I’ve also tried manually creating a PVC to see if it binds correctly, which it does without scenario. I’ve run `kubectl get pvc` and found the following status for my generated PVC: ``` NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE my-data-my-statefulset-0 Pending ``` It stays in `Pending`. I suspect there might be a misconfiguration somewhere or an scenario with the default StorageClass. Any insights on how to troubleshoot this further or what might be causing the PVC to stay unbound would be greatly appreciated. My development environment is Windows. Is there a better approach? This issue appeared after updating to Yaml stable. Thanks for taking the time to read this! I've been using Yaml for about a year now. Any advice would be much appreciated.