Qdrant
by qdrantHigh-performance vector search engine and database written in Rust. Production-grade, filterable payloads, REST + gRPC APIs.
README
Vector Search Engine for the next generation of AI applications
Qdrant (read: _quadrant_) is a vector similarity search engine and vector database. It provides a production-ready service with a convenient API to store, search, and manage points—vectors with an additional payload. Qdrant is tailored for extended filtering support, making it useful for all sorts of neural-network or semantic-based matching, faceted search, and other applications.
Qdrant is written in Rust 🦀, which makes it fast and reliable even under high load. See benchmarks.
With Qdrant, embeddings or neural network encoders can be turned into full-fledged applications for matching, searching, recommending, and much more!
Qdrant is also available as a fully managed Qdrant Cloud ⛅ including a free tier.
Quick Start • Agent Skills • Client Libraries • Demo Projects • Integrations • Contact
</strong> </p> Qdrant provides a collection of ready-to-use agent skills that bring Qdrant's vector search capabilities directly into your AI coding assistant. Install these skills to empower your agent in making critical engineering decisions for optimal vector search performance, such as quantization, sharding, tenant isolation, hybrid search, model migration, and more. To experience the full power of Qdrant locally, run the container with this command: Note that this starts an insecure deployment without authentication, open to all network interfaces. Please refer to secure your instance. Now you can connect to the server with any client. For example, using Python: Before deploying Qdrant to production, be sure to read our installation and security guides. Qdrant offers the following client libraries to help you integrate it into your application stack: Qdrant Edge is a lightweight version of Qdrant designed for edge devices and resource-constrained environments. Unlike Qdrant Server, which uses a client-server architecture, Qdrant Edge runs inside the application process. Data is stored and queried locally and can be synchronized with a Qdrant server. It offers the same powerful vector search capabilities as the client-server version but with a smaller footprint, making it ideal for applications that require low latency and offline functionality. To get started with Qdrant Edge from Python or Rust, initialize an instance of EdgeShard, which exposes methods to manage data, query it, and restore snapshots. For example: Unlock the power of semantic embeddings with Qdrant, transcending keyword-based search to find meaningful connections in short texts. Deploy a neural search in minutes using a pre-trained neural network, and experience the future of text search. Try it online! There's more to discovery than text search, especially when it comes to food. People often choose meals based on appearance rather than descriptions and ingredients. Let Qdrant help your users find their next delicious meal using visual search, even if they don't know the dish's name. Check it out! Enter the cutting-edge realm of extreme classification, an emerging machine learning field tackling multi-class and multi-label problems with millions of labels. Harness the potential of similarity learning models, and see how a pre-trained transformer model and Qdrant can revolutionize e-commerce product categorization. Play with it online! Qdrant provides a REST API with an OpenAPI 3.0 specification, enabling client generation for virtually any framework or programming language. You can also download the raw OpenAPI definitions. For faster, production-tier searches, Qdrant also provides a gRPC interface. Qdrant supports dense vectors for semantic similarity, sparse vectors for full-text search, and multivector search for objects with multiple embeddings or late interaction models like ColBERT. Attach any JSON payload to your vectors and filter on it using a rich set of conditions—keyword matching, full-text, numeric ranges, geo-locations, and more—combined with Combine multiple vectors in a single query to get the best of semantic understanding and keyword precision, with results merged via configurable fusion strategies, such as Reciprocal Rank Fusion (RRF) and Distribution-Based Score Fusion (DBSF). Built-in quantization cuts RAM usage by up to 97% and lets you tune the trade-off between search speed and precision. Scale horizontally with sharding and replication, and update or resize collections with zero downtime. Web UI provides a visual way to interact with your data and monitor the health of your deployment. It enables you to explore your collections, manage data, interact with the REST API, and more. Qdrant integrates with the tools you're already using across every stage of your AI stack. You can connect to embedding providers, AI application frameworks, and data pipeline tools, as well as observability platforms for monitoring and tracing your vector search in production. No-code and low-code automation platforms are supported too. Refer to the Ecosystem page for the complete list. We are happy to receive your contributions! Before opening a pull request, please read our Contributing Guide. Qdrant is licensed under the Apache License, Version 2.0. View a copy of the License file.Getting Started
Agent Skills
Client-Server
docker run -p 6333:6333 qdrant/qdrantfrom qdrant_client import QdrantClient
client = QdrantClient(url="http://localhost:6333")Clients
- [Go client](https://github.com/qdrant/go-client)
- [Rust client](https://github.com/qdrant/rust-client)
- [JavaScript/TypeScript client](https://github.com/qdrant/qdrant-js)
- [Python client](https://github.com/qdrant/qdrant-client)
- [.NET/C# client](https://github.com/qdrant/qdrant-dotnet)
- [Java client](https://github.com/qdrant/java-client)
- [PHP](https://github.com/hkulekci/qdrant-php)
Qdrant Edge
from qdrant_edge import Distance, EdgeConfig, EdgeVectorParams, EdgeShard, Point, UpdateOperation
shard = EdgeShard.create("./shard", EdgeConfig(
vectors={"my-vector": EdgeVectorParams(size=4, distance=Distance.Cosine)}
))
shard.update(UpdateOperation.upsert_points([
Point(id=1, vector={"my-vector": [0.1, 0.2, 0.3, 0.4]}, payload={"color": "red"})
]))Where Do I Go from Here?
Demo Projects
Discover Semantic Text Search 🔍
Explore Similar Image Search - Food Discovery 🍕
Master Extreme Classification - E-Commerce Product Categorization 📺
API
REST
gRPC
Features
Dense, Sparse, and Multi Vector Search
Filtering on Payload
should, must, and must_not clauses.Hybrid Search
Vector Quantization and On-Disk Storage
Distributed Deployment
Highlighted Features
io_uring to maximize disk throughput utilization even on network-attached storage.Web UI

Integrations
Contributing
[!IMPORTANT]
Our development branch is
dev, not master. Please fork the repo, branch from dev, and open your pull request against dev. PRs targeting master will be asked to retarget.Contacts
License