README.mdβ’16.2 kB
<div style="display: flex; justify-content: space-between; align-items: flex-start; width: 100%; padding: 1em 0;">
  <!-- Logo -->
  <div>
    <img align="left" src="media/deslicer_white.svg" alt="Deslicer" width="200">
  </div>
</div>
# MCP Server for Splunk
[](https://gofastmcp.com/)
[](https://python.org)
[](https://docker.com)
[](https://modelcontextprotocol.io/)
[](#)
[](#)
[](LICENSE)
> **Enable AI agents to interact seamlessly with Splunk environments through the Model Context Protocol (MCP)**
Transform your Splunk instance into an AI-native platform. Our community-driven MCP server bridges Large Language Models and Splunk Enterprise/Cloud with 20+ tools, 14 resources, and production-ready securityβall through a single, standardized protocol.
## π Why This Matters
- **π Universal AI Connection**: One protocol connects any AI to Splunk data
- **β‘ Zero Custom Integration**: No more months of custom API development
- **π‘οΈ Production-Ready Security**: Client-scoped access with no credential exposure
- **π€ AI-Powered Workflows**: Intelligent troubleshooting agents that work like experts
- **π€ Community-Driven**: Extensible framework with contribution examples
> **π NEW: [AI-Powered Troubleshooting Workflows](docs/guides/workflows/README.md)** - Transform reactive firefighting into intelligent, systematic problem-solving with specialist AI workflows.
## π Table of Contents
- [π Quick Start](#quick-start)
  - [Prerequisites](#prerequisites)
  - [Configuration](#configuration)
  - [One-Command Setup](#one-command-setup)
- [π― What You Can Do](#what-you-can-do)
  - [π€ AI-Powered Troubleshooting](#ai-powered-troubleshooting-new)
- [π Documentation Hub](#documentation-hub)
- [π§ Available Tools & Capabilities](#available-tools--capabilities)
  - [π€ AI Workflows & Specialists](#ai-workflows--specialists-new)
  - [π Search & Analytics](#search--analytics)
  - [π Data Discovery](#data-discovery)
  - [π₯ Administration](#administration)
  - [π₯ Health Monitoring](#health-monitoring)
- [π Client Integration Examples](#client-integration-examples)
  - [π Multi-Client Benefits](#multi-client-benefits)
  - [Cursor IDE](#cursor-ide)
  - [Google Agent Development Kit](#google-agent-development-kit)
- [π€ Community & Contribution](#community--contribution)
  - [π οΈ Create Your Own Tools & Extensions](#create-your-own-tools--extensions)
  - [Contribution Categories](#contribution-categories)
- [π Deployment Options](#deployment-options)
  - [Development (Local)](#development-local)
  - [Production (Docker)](#production-docker)
  - [Enterprise (Kubernetes)](#enterprise-kubernetes)
- [π Support & Community](#support--community)
  - [Windows Support](#windows-support)
- [π Project Stats](#project-stats)
- [π― Ready to Get Started?](#ready-to-get-started)
<a name="quick-start"></a>
## π Quick Start
<a name="prerequisites"></a>
### Prerequisites
- Python 3.10+ and UV package manager
- Nodejs (optional used for mcp inspector)
- Docker (optional but recommended for full stack)
- Splunk instance with API access (or use included Docker Splunk)
> **π Complete Setup Guide**: [Installation Guide](docs/getting-started/installation.md)
<a name="configuration"></a>
### Configuration
**Before running the setup, configure your Splunk connection:**
```bash
# Copy the example configuration
cp env.example .env
# Edit .env with your Splunk credentials
# - Use your existing Splunk instance (local, cloud, or Splunk Cloud)
# - OR use the included Docker Splunk (requires Docker)
```
<a name="one-command-setup"></a>
### One-Command Setup
**Windows:**
```powershell
git clone https://github.com/deslicer/mcp-for-splunk.git
cd mcp-for-splunk
```python
# Start the MCP Server (project script)
uv run mcp-server --local --detached
# Verify the server
uv run mcp-server --test
# Optional: show detailed tools/resources and health output
uv run mcp-server --test --detailed
```
**macOS/Linux:**
```bash
git clone https://github.com/deslicer/mcp-for-splunk.git
cd mcp-for-splunk
# (Recommended) Preview what would be installed
./scripts/smart-install.sh --dry-run
# Install missing prerequisites (base: Python, uv, Git, Node)
./scripts/smart-install.sh
# Start the MCP Server (project script)
uv run mcp-server --local --detached
# Verify the server
uv run mcp-server --test
# Optional: show detailed tools/resources and health output
uv run mcp-server --test --detailed
```
> **π‘ Deployment Options**: The `mcp-server` command will prompt you to choose:
> - **Docker** (Option 1): Full stack with Splunk, Traefik, MCP Inspector - recommended if Docker is installed
> - **Local** (Option 2): Lightweight FastMCP server only - for users without Docker
> Note on Splunk licensing: When using the `so1` Splunk container, you must supply your own Splunk Enterprise license if required. The compose files include a commented example mount:
> `# - ./lic/splunk.lic:/tmp/license/splunk.lic:ro`. Create a `lic/` directory and mount your license file, or add the license via the Splunk Web UI after startup.
<a name="what-you-can-do"></a>
## π― What You Can Do
<a name="ai-powered-troubleshooting-new"></a>
### π€ **AI-Powered Troubleshooting** (NEW!)
Transform your Splunk troubleshooting from manual procedures to intelligent, automated workflows using the MCP server endpoints:
```python
# Discover and execute intelligent troubleshooting workflows
result = await list_workflows.execute(ctx, format_type="summary")
# Returns: missing_data_troubleshooting, performance_analysis, custom_workflows...
# Run AI-powered troubleshooting with a single command
result = await workflow_runner.execute(
    ctx=ctx,
    workflow_id="missing_data_troubleshooting",
    earliest_time="-24h",
    latest_time="now",
    focus_index="main"
)
# β Parallel execution, expert analysis, actionable recommendations
```
**π Key Benefits:**
- **π§  Natural Language Interface**: "Troubleshoot missing data" β automated workflow execution
- **β‘ Parallel Processing**: Multiple diagnostic tasks run simultaneously for faster resolution
- **π§ Custom Workflows**: Build organization-specific troubleshooting procedures
- **π Intelligent Analysis**: AI agents follow proven Splunk best practices
**[π Read the Complete AI Workflows Guide β](docs/guides/workflows/README.md)** for detailed examples, workflow creation, and advanced troubleshooting techniques.
<a name="documentation-hub"></a>
## π Documentation Hub
| Document | Purpose | Audience | Time |
|----------|---------|----------|------|
| **[π€ AI-Powered Troubleshooting](docs/guides/workflows/README.md)** | **Intelligent workflows powered by the workflow tools** | **All users** | **5 min** |
| **[Getting Started](docs/getting-started/)** | Complete setup guide with prerequisites | New users | 15 min |
| **[Integration Guide](docs/guides/integration/)** | Connect AI clients | Developers | 30 min |
| **[Deployment Guide](docs/guides/deployment/)** | Production deployment | DevOps | 45 min |
| **[Workflows Guide](docs/guides/workflows/README.md)** | Create and run workflows (OpenAI env vars) | Developers | 10 min |
| **[API Reference](docs/reference/tools.md)** | Tool documentation | Integrators | Reference |
| **[Contributing](docs/contrib/contributing.md)** | Add your own tools | Contributors | 60 min |
| **[π Contrib Guide](contrib/README.md)** | **Complete contribution framework** | **Contributors** | **15 min** |
| **[Architecture](docs/architecture/)** | Technical deep-dive | Architects | Reference |
| **[Tests Quick Start](docs/tests.md)** | First success test steps | Developers | 2 min |
<a name="available-tools--capabilities"></a>
## π§ Available Tools & Capabilities
<a name="ai-workflows--specialists-new"></a>
### π€ **AI Workflows & Specialists** (NEW!)
- **`list_workflows`**: Discover available troubleshooting workflows (core + contrib)
- **`workflow_runner`**: Execute any workflow with full parameter control and progress tracking
- **`workflow_builder`**: Create custom troubleshooting procedures for your organization
- **Built-in Workflows**: Missing data troubleshooting, performance analysis, and more
- **[π Complete Workflow Guide β](docs/guides/workflows/README.md)**
<a name="search--analytics"></a>
### π Search & Analytics
- **Smart Search**: Natural language to SPL conversion
- **Real-time Search**: Background job management with progress tracking
- **Saved Searches**: Create, execute, and manage search automation
<a name="data-discovery"></a>
### π Data Discovery
- **Metadata Exploration**: Discover indexes, sources, and sourcetypes
- **Schema Analysis**: Understand your data structure
- **Usage Patterns**: Identify data volume and access patterns
<a name="administration"></a>
### π₯ Administration
- **App Management**: List, enable, disable Splunk applications
- **User Management**: Comprehensive user and role administration
- **Configuration Access**: Read and analyze Splunk configurations
<a name="health-monitoring"></a>
### π₯ Health Monitoring
- **System Health**: Monitor Splunk infrastructure status
- **Degraded Feature Detection**: Proactive issue identification
- **Alert Management**: Track and analyze triggered alerts
<a name="client-integration-examples"></a>
## π Client Integration Examples
**πͺ Multi-Client Configuration Strength**: One of the key advantages of this MCP Server for Splunk is its ability to support multiple client configurations simultaneously. You can run a single server instance and connect multiple clients with different Splunk environments, credentials, and configurations - all without restarting the server or managing separate processes.
<a name="multi-client-benefits"></a>
### π Multi-Client Benefits
**Session-Based Isolation**: Each client connection maintains its own Splunk session with independent authentication, preventing credential conflicts between different users or environments.
**Dynamic Configuration**: Switch between Splunk instances (on-premises, cloud, development, production) by simply changing headers - no server restart required.
**Scalable Architecture**: A single server can handle multiple concurrent clients, each with their own Splunk context, making it ideal for team environments, CI/CD pipelines, and multi-tenant deployments.
**Resource Efficiency**: Eliminates the need to run separate MCP server instances for each Splunk environment, reducing resource consumption and management overhead.
<a name="cursor-ide"></a>
### Cursor IDE
## Single Tenant ##
```json
{
  "mcpServers": {
    "splunk": {
      "command": "fastmcp",
      "args": ["run", "/path/to/src/server.py"],
      "env": {
        "MCP_SPLUNK_HOST": "your-splunk.com",
        "MCP_SPLUNK_USERNAME": "your-user"
      }
    }
  }
}
```
## Client Specified Tenant ##
```json
{
    "mcpServers": {
      "splunk-in-docker": {
        "url": "http://localhost:8002/mcp/",
        "headers": {
          "X-Splunk-Host": "so1",
          "X-Splunk-Port": "8089",
          "X-Splunk-Username": "admin",
          "X-Splunk-Password": "Chang3d!",
          "X-Splunk-Scheme": "http",
          "X-Splunk-Verify-SSL": "false",
          "X-Session-ID": "splunk-in-docker-session"
        }
    },
        "splunk-cloud-instance": {
        "url": "http://localhost:8002/mcp/",
        "headers": {
          "X-Splunk-Host": "myorg.splunkcloud.com",
          "X-Splunk-Port": "8089",
          "X-Splunk-Username": "admin@myorg.com",
          "X-Splunk-Password": "Chang3d!Cloud",
          "X-Splunk-Scheme": "https",
          "X-Splunk-Verify-SSL": "true",
          "X-Session-ID": "splunk-cloud-session"
        }
    }
  }
}
```
<a name="google-agent-development-kit"></a>
### Google Agent Development Kit
```python
from google.adk.tools.mcp_tool.mcp_toolset import MCPToolset
splunk_agent = LlmAgent(
    model='gemini-2.0-flash',
    tools=[MCPToolset(connection_params=StdioServerParameters(
        command='fastmcp',
        args=['run', '/path/to/src/server.py']
    ))]
)
```
<a name="community--contribution"></a>
## π€ Community & Contribution
Quick links: [Contributing](CONTRIBUTING.md) Β· [Code of Conduct](CODE_OF_CONDUCT.md) Β· [Security Policy](SECURITY.md) Β· [Governance](GOVERNANCE.md) Β· [License](LICENSE)
<a name="create-your-own-tools--extensions"></a>
### π οΈ **Create Your Own Tools & Extensions**
**π Quick Start for Contributors:**
```bash
# Interactive tool generator (project script)
uv run generate-tool
# Browse existing tools for inspiration
./contrib/scripts/list_tools.py
# Validate your tool implementation (project script)
uv run validate-tools
# Test your contribution
./contrib/scripts/test_contrib.py
```
**[π Complete Contributing Guide β](contrib/README.md)** - Everything you need to know about creating tools, resources, and workflows for the MCP Server for Splunk.
<a name="contribution-categories"></a>
### **Contribution Categories**
- **π‘οΈ Security Tools**: Threat hunting, incident response, security analysis
- **βοΈ DevOps Tools**: Monitoring, alerting, operations, SRE workflows
- **π Analytics Tools**: Business intelligence, reporting, data analysis
- **π‘ Example Tools**: Learning templates and patterns for new contributors
- **π§ Custom Workflows**: AI-powered troubleshooting procedures for your organization
<a name="deployment-options"></a>
## π Deployment Options
<a name="development-local"></a>
### Development (Local)
- **Startup Time**: ~10 seconds
- **Resource Usage**: Minimal (single Python process)
- **Best For**: Development, testing, stdio-based AI clients
<a name="production-docker"></a>
### Production (Docker)
- **Features**: Load balancing, health checks, monitoring
- **Includes**: Traefik, MCP Inspector, optional Splunk
- **Best For**: Multi-client access, web-based AI agents
<a name="enterprise-kubernetes"></a>
### Enterprise (Kubernetes)
- **Scalability**: Horizontal scaling, high availability
- **Security**: Pod-level isolation, secret management
- **Monitoring**: Comprehensive observability stack
<a name="support--community"></a>
## π Support & Community
- **π Issues**: [GitHub Issues](https://github.com/deslicer/mcp-server-for-splunk/issues)
- **π¬ Discussions**: [GitHub Discussions](https://github.com/deslicer/mcp-server-for-splunk/discussions)
- **π Documentation**: Complete guides and references
- **π§ Interactive Testing**: MCP Inspector for real-time testing
<a name="windows-support"></a>
### Windows Support
Windows users get first-class support with PowerShell scripts and comprehensive troubleshooting guides. See our [Windows Setup Guide](docs/WINDOWS_GUIDE.md).
<a name="project-stats"></a>
## π Project Stats
- β
 **20+ Production Tools** - Comprehensive Splunk operations
- β
 **14 Rich Resources** - System info and documentation access
- β
 **Comprehensive Test Suite** - 170+ tests passing locally
- β
 **Multi-Platform** - Windows, macOS, Linux support
- β
 **Community-Ready** - Structured contribution framework
- β
 **Enterprise-Proven** - Production deployment patterns
---
<a name="ready-to-get-started"></a>
## π― Ready to Get Started?
Choose your adventure:
- **π [Quick Start](docs/getting-started/)** - Get running in 15 minutes
- **π» [Integration Examples](docs/guides/integration/)** - Connect your AI tools
- **ποΈ [Architecture Guide](docs/architecture/)** - Understand the system
- **π€ [Contribute](docs/contrib/contributing.md)** - Add your own tools
**Learn More**: [Model Context Protocol](https://modelcontextprotocol.io/) | [FastMCP Framework](https://gofastmcp.com/)