惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Martin Fowler
Martin Fowler
P
Palo Alto Networks Blog
大猫的无限游戏
大猫的无限游戏
Cisco Talos Blog
Cisco Talos Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
月光博客
月光博客
The GitHub Blog
The GitHub Blog
H
Hacker News: Front Page
Simon Willison's Weblog
Simon Willison's Weblog
T
Troy Hunt's Blog
GbyAI
GbyAI
S
Security Affairs
博客园 - 司徒正美
博客园_首页
Stack Overflow Blog
Stack Overflow Blog
Webroot Blog
Webroot Blog
J
Java Code Geeks
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
V
V2EX
量子位
Project Zero
Project Zero
美团技术团队
C
Cisco Blogs
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
AI
AI
P
Privacy International News Feed
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
L
LangChain Blog
罗磊的独立博客
A
About on SuperTechFans
S
Securelist
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Recent Commits to openclaw:main
Recent Commits to openclaw:main
S
SegmentFault 最新的问题
M
MIT News - Artificial intelligence
MongoDB | Blog
MongoDB | Blog
Forbes - Security
Forbes - Security
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Last Week in AI
Last Week in AI
S
Secure Thoughts
Scott Helme
Scott Helme
www.infosecurity-magazine.com
www.infosecurity-magazine.com
H
Help Net Security
I
Intezer
Hacker News: Ask HN
Hacker News: Ask HN
C
Cybersecurity and Infrastructure Security Agency CISA
T
The Exploit Database - CXSecurity.com
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
Latest news
Latest news

OneUptime Blog

How to Monitor Azure App Services (PaaS) with OpenTelemetry Grafana Stack vs OneUptime: DIY Observability or Unified Platform? Your AI Workloads Are About to Blow Up Your Observability Bill The Great Observability Consolidation Is Here How to Write Custom Object Classes for Ceph How to Write Custom Ceph Manager Modules How to Write a ceph.conf Configuration File How to Use Rook-Ceph with OpenShift How to Use Rook-Ceph with Longhorn for Comparison How to Configure Volume Snapshot Class for RBD in Rook How to Configure VolumeReplicationClass Scheduling Intervals in Rook How to Set Up Volume Replication with Rook-Ceph How to Create Volume Group Snapshots with Rook CSI How to Visualize Ceph Network Performance in Grafana How to Enable Virtual Host-Style Bucket Access in Rook How to View Runtime Configuration via Admin Socket How to View Quota Settings and Update Stats in Ceph RGW How to View PG Scaling Recommendations with autoscale-status How to View PG Distribution via Admin Socket How to View Performance Metrics in the Ceph Dashboard How to View OSD Performance Counters in Ceph How to View Connection Status via Admin Socket How to View Ceph Cluster Summary Dashboard via CLI How to Version Control Rook-Ceph Configuration How to Version Control Ceph Infrastructure with Terraform How to Verify Kubernetes Node Requirements for Rook-Ceph Deployment How to Verify Health Before and After Rook Upgrades How to Verify Data Integrity with Deep Scrubbing How to Verify Complete Rook-Ceph Cleanup How to Verify Backup Integrity from Ceph Snapshots How to Use Rook-Ceph with Velero for Kubernetes Backup How to Integrate HashiCorp Vault with Rook-Ceph (Token Auth) How to Configure TLS for Vault Integration in Rook How to Integrate HashiCorp Vault with Rook-Ceph (Kubernetes Auth) How to Validate Ceph Cluster Configuration After Deployment How to Understand User Type and ID Notation (TYPE.ID) in Ceph How to Configure User Management in the Ceph Dashboard How to Use Rook-Ceph with Helm Chart Deployments How to Use the Swift API with Ceph RGW How to Use SQLite Databases Stored on Ceph How to Use s3cmd with Ceph RGW How to Use the S3 API with Ceph RGW How to Use Red Hat Ceph with RHEL Virtualization How to Use RBD with QEMU How to Use RBD with Nomad How to Use RBD with CloudStack How to Use RBD Snapshot Rollback How to Use rados bench for Object Storage Benchmarking How to Secure Rook-Ceph with Pod Security Admission How to Use pg-upmap for PG Mapping in Ceph How to Use Multipath Devices with Ceph OSDs How to Use MinIO Client (mc) with Ceph RGW How to Use fs swap for CephFS How to Use fio for Ceph Block Storage Benchmarking How to Use the CephFS Shell How to Use Ceph RGW for Media Asset Management How to Use Ceph RGW for Log Storage and Archival How to Use Ceph RGW for Data Lake Storage How to Use Ceph RGW for Backup Repository Storage How to Use the ceph-authtool Utility How to Use boto3 (Python) with Ceph RGW S3 How to Use AWS CLI with Ceph RGW S3 How to Use the Admin Ops API with Ceph RGW How to Configure Usage Log Key Transition in Ceph RGW How to Handle Rook-Ceph Upgrades in GitOps Pipelines How to Upgrade Rook-Ceph with Zero Downtime How to Create a Ceph Upgrade Runbook How to Upgrade the Rook Operator from v1.18 to v1.19 How to Upgrade the Rook Operator on Kubernetes How to Upgrade External Cluster Connections in Rook How to Upgrade the Ceph Version in Rook How to Upgrade from Ceph Reef to Squid How to Upgrade from Ceph Quincy to Reef How to Upgrade Ceph Clusters in Stretch Mode How to Update Kernel for CephFS Feature Compatibility How to Update Ceph Configuration on a Running Rook Cluster How to Create Unique Kubernetes Services per NFS Server in Rook How to Understand When Compression Helps vs Hurts in Ceph How to Understand User Types (Individual vs System) in Ceph How to Understand the undersized PG State in Ceph How to Understand the stale PG State in Ceph How to Understand the repair PG State in Ceph How to Understand the remapped PG State in Ceph How to Understand Red Hat Ceph Storage vs Upstream Ceph How to Understand Placement Groups in Ceph How to Understand PG Splitting in Ceph How to Understand the peering PG State in Ceph How to Understand OSD Recovery Process in Ceph How to Understand the OSD Map in Ceph How to Understand New Features in Each Ceph Release How to Understand Monitor Leadership in Ceph How to Understand MDS States in CephFS How to Understand Deprecated Features in Ceph Reef How to Understand the degraded PG State in Ceph How to Understand D3N in Ceph How to Understand the creating PG State in Ceph How to Understand the clean PG State in Ceph How to Understand CephX Authentication Protocol How to Understand CephX Authentication Flow How to Understand What Data Ceph Telemetry Collects
How to Use Rook-Ceph with Kubernetes Operators
Nawaz Dhandala · 2026-03-31 · via OneUptime Blog

Kubernetes Operators automate the lifecycle of complex applications like databases and message queues. Rook-Ceph integrates with these operators by providing StorageClasses that operators use to provision persistent storage automatically when creating managed resources.

How Operators Use Storage

Most database operators (PostgreSQL, MySQL, Kafka, etc.) accept a storageClassName in their CRD spec. The operator then creates PVCs using that StorageClass for the resources it manages. Rook-Ceph simply needs to provide appropriately configured StorageClasses.

Creating Operator-Ready StorageClasses

Operators need different storage profiles depending on the workload:

# High-performance block storage for databases
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: rook-ceph-operator-db
provisioner: rook-ceph.rbd.csi.ceph.com
parameters:
  clusterID: rook-ceph
  pool: database-pool
  imageFormat: "2"
  imageFeatures: layering
  csi.storage.k8s.io/provisioner-secret-name: rook-csi-rbd-provisioner
  csi.storage.k8s.io/provisioner-secret-namespace: rook-ceph
  csi.storage.k8s.io/node-stage-secret-name: rook-csi-rbd-node
  csi.storage.k8s.io/node-stage-secret-namespace: rook-ceph
reclaimPolicy: Retain
allowVolumeExpansion: true
volumeBindingMode: WaitForFirstConsumer

Integrating with CloudNativePG (PostgreSQL Operator)

CloudNativePG is a popular PostgreSQL operator that uses StorageClasses for data and WAL volumes:

apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
  name: postgres-cluster
  namespace: databases
spec:
  instances: 3
  storage:
    size: 100Gi
    storageClass: rook-ceph-operator-db
  walStorage:
    size: 20Gi
    storageClass: rook-ceph-operator-db
  backup:
    barmanObjectStore:
      destinationPath: s3://pg-backups
      endpointURL: http://rook-ceph-rgw-backup-store.rook-ceph.svc.cluster.local
      s3Credentials:
        accessKeyId:
          name: pg-backup-creds
          key: ACCESS_KEY_ID
        secretAccessKey:
          name: pg-backup-creds
          key: SECRET_ACCESS_KEY

Integrating with Strimzi (Kafka Operator)

Strimzi deploys Apache Kafka and uses StorageClasses per broker:

apiVersion: kafka.strimzi.io/v1beta2
kind: Kafka
metadata:
  name: my-kafka
  namespace: messaging
spec:
  kafka:
    replicas: 3
    storage:
      type: persistent-claim
      size: 200Gi
      class: rook-ceph-operator-db
      deleteClaim: false
  zookeeper:
    replicas: 3
    storage:
      type: persistent-claim
      size: 10Gi
      class: rook-ceph-operator-db

Integrating with Redis Operator (Redis Enterprise)

Configure the Redis Operator to use Rook storage:

apiVersion: app.redislabs.com/v1
kind: RedisEnterpriseCluster
metadata:
  name: rec
  namespace: redis
spec:
  nodes: 3
  redisEnterpriseNodeResources:
    requests:
      memory: 4Gi
  persistentSpec:
    enabled: true
    storageClassName: rook-ceph-operator-db
    volumeSize: 20Gi

Monitoring PVC Lifecycle Across Operators

Track PVC usage across all operators:

# List all PVCs across namespaces with their StorageClass
kubectl get pvc -A \
  -o custom-columns='NAMESPACE:.metadata.namespace,NAME:.metadata.name,CLASS:.spec.storageClassName,SIZE:.spec.resources.requests.storage,STATUS:.status.phase'

# Find PVCs using Rook StorageClasses
kubectl get pvc -A | grep rook-ceph

Summary

Rook-Ceph integrates with Kubernetes Operators by providing StorageClasses that operators reference when provisioning persistent volumes. CloudNativePG, Strimzi, and Redis operators all accept storageClass fields in their CRD specs. A well-designed set of Rook StorageClasses covering different performance profiles (with reclaimPolicy: Retain and WaitForFirstConsumer) gives operators the flexibility they need while protecting data from accidental deletion.