mcp-server-opensearch: An OpenSearch MCP Server
The Model Context Protocol (MCP)β is an open protocol that enables seamless integration between LLM applications and external data sources and tools. Whether youβre building an AI-powered IDE, enhancing a chat interface, or creating custom AI workflows, MCP provides a standardized way to connect LLMs with the context they need.
This repository is an example of how to create a MCP server for OpenSearchβ, a distributed search and analytics engine.
Under Contruction

Current Blocker - Async Client from OpenSearch isnβt installing
Open Search Async Client Docsβ
pip install opensearch-py[async]
zsh: no matches found: opensearch-py[async]Overview
A basic Model Context Protocol server for keeping and retrieving memories in the OpenSearch engine. It acts as a semantic memory layer on top of the OpenSearch database.
Components
Tools
search-openSearch- Store a memory in the OpenSearch database
- Input:
query(json): prepared json query message
- Returns: Confirmation message
Installation
Installing via Smithery
To install mcp-server-opensearch for Claude Desktop automatically via Smitheryβ:
npx -y @smithery/cli install @ibrooksSDX/mcp-server-opensearch --client claudeUsing uv (recommended)
When using uv no specific installation is needed to directly run mcp-server-opensearch.
uv run mcp-server-opensearch \
--opensearch-url "http://localhost:9200" \
--index-name "my_index" \or
uv run fastmcp run demo.py:mainTesting - Local Open Search Client

uv run python src/mcp-server-opensearch/test_opensearch.pyTesting - MCP Server Connection to Open Search Client

cd src/mcp-server-opensearch
uv run fastmcp dev demo.pyUsage with Claude Desktop
To use this server with the Claude Desktop app, add the following configuration to the βmcpServersβ section of your claude_desktop_config.json:
{
"opensearch": {
"command": "uvx",
"args": [
"mcp-server-opensearch",
"--opensearch-url",
"http://localhost:9200",
"--opensearch-api-key",
"your_api_key",
"--index-name",
"your_index_name"
]
}, "Demo": {
"command": "uv",
"args": [
"run",
"--with",
"fastmcp",
"--with",
"opensearch-py",
"fastmcp",
"run",
"/Users/ibrooks/Documents/GitHub/mcp-server-opensearch/src/mcp-server-opensearch/demo.py"
]
}
}Or use the FastMCP UI to install the server to Claude
uv run fastmcp install demo.pyEnvironment Variables
The configuration of the server can be also done using environment variables:
OPENSEARCH_HOST: URL of the OpenSearch server, e.g.http://localhostOPENSEARCH_HOSTPORT: Port of the host of the OpenSearch server9200INDEX_NAME: Name of the index to use