qdrant-vertical-scaling
Guides Qdrant vertical scaling decisions. Use when someone asks 'how to scale up a node', 'need more RAM', 'upgrade node size', 'vertical scaling', 'resize cluster', 'scale up vs scale out', or when memory/CPU is insufficient on current nodes. Also use when someone wants to avoid the complexity of horizontal scaling.
git clone --depth 1 https://github.com/qdrant/skills /tmp/qdrant-vertical-scaling && cp -r /tmp/qdrant-vertical-scaling/skills/qdrant-scaling/scaling-data-volume/vertical-scaling ~/.claude/skills/qdrant-vertical-scalingSKILL.md
# What to Do When Qdrant Needs to Scale Vertically Vertical scaling means increasing CPU, RAM, or disk on existing nodes rather than adding more nodes. This is the recommended first step before considering horizontal scaling. Vertical scaling is simpler, avoids distributed system complexity, and is reversible. - Vertical scaling for Qdrant Cloud is done through the [Qdrant Cloud Console](https://cloud.qdrant.io/) - For self-hosted deployments, resize the underlying VM or container resources ## When to Scale Vertically Use when: current node resources (RAM, CPU, disk) are insufficient, but the workload doesn't yet require distribution. - RAM usage approaching 80% of available memory (OS page cache eviction starts, severe performance degradation) - CPU saturation during query serving or indexing - Disk space running low for on-disk vectors and payloads - A single node can handle up to ~100M vectors depending on dimensions and quantization - For non-production workloads, which are tolerant to single-point-of-failure and don't require high availability ## How to Scale Vertically in Qdrant Cloud Vertical scaling is managed through the Qdrant Cloud Console. - Log into [Qdrant Cloud Console](https://cloud.qdrant.io/) or use [CLI tool](https://github.com/qdrant/qcloud-cli) - Select the cluster to resize - Choose a larger node configuration (more RAM, CPU, or both) - The upgrade process involves a rolling restart with no downtime if replication is configured - Ensure `replication_factor: 2` or higher before resizing to maintain availability during the rolling restart **Important:** Scaling up is straightforward. Scaling down requires care -- if the working set no longer fits in RAM after downsizing, performance will degrade severely due to cache eviction. Always load test before scaling down. ## RAM Sizing Guidelines RAM is the most critical resource for Qdrant performance. Use these guidelines to right-size. - Exact estimation of RAM usage is difficult; use this simple approximate formula: `num_vectors * dimensions * 4 bytes * 1.5` for full-precision vectors in RAM - With scalar quantization: divide by 4 (INT8 reduces each float32 to 1 byte) [Quantization](https://skills.qdrant.tech/md/documentation/manage-data/quantization/) - With binary quantization: divide by 32 [Binary quantization](https://skills.qdrant.tech/md/documentation/manage-data/quantization/?s=binary-quantization) - Add overhead for HNSW index (~20-30% of vector data), payload indexes, and WAL - Reserve 20% headroom for optimizer operations and OS cache - Monitor actual usage via Grafana/Prometheus before and after resizing [Monitoring](../../../qdrant-monitoring/SKILL.md) ## When Vertical Scaling Is No Longer Enough Recognize these signals that it's time to go horizontal: - Data volume exceeds what a single node can hold even with quantization and mmap - IOPS are saturated (more nodes = more independent disk I/O) - Need fault tolerance (requires replication across nodes) - Need tenant isolation via dedicated shards - Single-node CPU is maxed and query latency is unacceptable - Next vertical scaling step is the largest available node size. You might need to be able to temporarily scale up to the larger node size to do batch operations or recovery. If you are already at the largest node size, you won't be able to do that. When you hit these limits, see [Horizontal Scaling](../horizontal-scaling/SKILL.md) for guidance on sharding and node planning. ## What NOT to Do - Do not scale down RAM without load testing first (cache eviction = severe latency degradation that can last days) - Do not ignore the 80% RAM threshold (performance cliff, not gradual degradation) - Do not skip replication before resizing in Cloud (rolling restart without replicas = downtime) - Do not jump to horizontal scaling before exhausting vertical options (adds permanent operational complexity) - Do not assume more CPU always helps (IOPS-bound workloads won't improve with more cores)
Qdrant provides client SDKs for various programming languages, allowing easy integration with Qdrant deployments.
Guides Qdrant deployment selection. Use when someone asks 'how to deploy Qdrant', 'Docker vs Cloud', 'local mode', 'embedded Qdrant', 'Qdrant EDGE', 'which deployment option', 'self-hosted vs cloud', or 'need lowest latency deployment'. Also use when choosing between deployment types for a new project.
Guides embedding model migration in Qdrant without downtime. Use when someone asks 'how to switch embedding models', 'how to migrate vectors', 'how to update to a new model', 'zero-downtime model change', 'how to re-embed my data', or 'can I use two models at once'. Also use when upgrading model dimensions, switching providers, or A/B testing models.
Guides Qdrant monitoring and observability setup. Use when someone asks 'how to monitor Qdrant', 'what metrics to track', 'is Qdrant healthy', 'optimizer stuck', 'why is memory growing', 'requests are slow', or needs to set up Prometheus, Grafana, or health checks. Also use when debugging production issues that require metric analysis.
Diagnoses Qdrant production issues using metrics and observability tools. Use when someone reports 'optimizer stuck', 'indexing too slow', 'memory too high', 'OOM crash', 'queries are slow', 'latency spike', or 'search was fast now it's slow'. Also use when performance degrades without obvious config changes.
Guides Qdrant monitoring setup including Prometheus scraping, health probes, Hybrid Cloud metrics, alerting, and log centralization. Use when someone asks 'how to set up monitoring', 'Prometheus config', 'Grafana dashboard', 'health check endpoints', 'how to scrape Hybrid Cloud', 'what alerts to set', 'how to centralize logs', or 'audit logging'.
Different techniques to optimize the performance of Qdrant, including indexing strategies, query optimization, and hardware considerations. Use when you want to improve the speed and efficiency of your Qdrant deployment.
Diagnoses and fixes slow Qdrant indexing and data ingestion. Use when someone reports 'uploads are slow', 'indexing takes forever', 'optimizer is stuck', 'HNSW build time too long', or 'data uploaded but search is bad'. Also use when optimizer status shows errors, segments won't merge, or indexing threshold questions arise.