Loading

Get started with vector search

If you want to get a sense of how vector search works in Elasticsearch, this quickstart is for you. First, you create an index and store your data in two forms: plain text and vector embeddings. Then you run a query that searches both representations and combines the results.

Note

This quickstart uses hybrid search: it combines keyword-based and vector search so you can match both exact terms and meaning. Keyword-based search matches exact terms in your data, while vector search understands the intent behind a query using embeddings.

For example, if a document contains the phrase "annual leave policy", a keyword search for "annual leave" will return it because the terms match. However, a search for "vacation rules" may not return the same document, because those exact words are not present.

With vector search, a query like "vacation rules" can still return the "annual leave policy" document, because it matches based on meaning rather than exact terms.

With hybrid search, the same query can return both keyword and semantic matches, combining exact words with search by meaning so results stay useful.

A running Elasticsearch cluster. For the fastest way to follow this quickstart, create a serverless project which includes a free Serverless trial.

  1. Create an index mapping

    Define the index mapping. The mapping specifies the fields in your index and their data types, including both plain text fields and fields used to store vector embeddings for vector search.

    				PUT semantic-embeddings
    					{
      "mappings": {
        "properties": {
          "semantic_text": {
            "type": "semantic_text"
          },
          "content": {
            "type": "text",
            "copy_to": "semantic_text"
          }
        }
      }
    }
    		
    1. The semantic_text field with the semantic_text field type to create and store vector embeddings. The default inference endpoint is used.
    2. The content field with the text field type to store plain text. This field is used for keyword search.
    3. Values indexed into content are copied to semantic_text and processed by the default inference endpoint.
  2. Index documents

    Index documents with the bulk API. You only need to provide the content to the content field. The copy_to mapping copies the text into semantic_text and generates embeddings, so you can run keyword search on content and vector search on semantic_text for the same document.

    				POST _bulk
    					{ "index": { "_index": "semantic-embeddings" } }
    { "content": "After running, cool down with light cardio for a few minutes to lower your heart rate and reduce muscle soreness." }
    { "index": { "_index": "semantic-embeddings" } }
    { "content": "Marathon plans stress weekly mileage; carb loading before a race does not replace recovery between hard sessions." }
    { "index": { "_index": "semantic-embeddings" } }
    { "content": "Tune cluster performance by monitoring thread pools and refresh interval." }
    		

Run a search using the Search API.

The JSON body is a hybrid query: a reciprocal rank fusion (RRF) retriever runs two match queries, one on content and one on semantic_text, and merges the results.

Note

An RRF retriever returns top documents based on the RRF formula. This enables hybrid search by combining results from both keyword-based and semantic queries into a single ranked list.

				GET semantic-embeddings/_search
					{
  "retriever": {
    "rrf": {
      "retrievers": [
        {
          "standard": { 
            "query": {
              "match": {
                "content": "muscle soreness after jogging"
              }
            }
          }
        },
        {
          "standard": { 
            "query": {
              "match": {
                "semantic_text": "muscle soreness after jogging"
              }
            }
          }
        }
      ]
    }
  }
}
		
  1. The match query is run against the content field, which stores plain text for keyword matching.
  2. The match query is run against the semantic_text field, which stores vector embeddings for meaning-based search.

If a document ranks well in either query, it can appear in the combined list.

  • Semantic search - Compare the three workflows (semantic_text, inference API, or models deployed in-cluster) and see how they differ in complexity.
  • Vector search - Work directly with dense_vector and sparse_vector fields, related queries, and manual vector implementations when you need control beyond managed semantic workflows.
  • Ranking and reranking - Structure multi-stage pipelines: initial BM25, vector, or hybrid retrieval, then reranking with stronger models on smaller candidate sets.
  • Build your search queries - Choose Query DSL, ES|QL, or retrievers on the Search API depending on whether you need classic queries, analytics-style pipes, or composable retrieval pipelines.