humio-mcp

islam3zzat/humio-mcp

3.2

If you are the rightful owner of humio-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

The Humio MCP Server is a Model Context Protocol server implementation designed to integrate seamlessly with Humio's logging and analytics platform.

Humio MCP Server

A Model Context Protocol (MCP) server implementation for Humio, enabling integration with Humio's logging and analytics platform.

Description

This project implements a server that bridges the Model Context Protocol with Humio's logging capabilities. It allows for seamless integration between applications and Humio's powerful logging and analytics features.

Prerequisites

  • Humio token

Installation

  1. Clone the repository:
git clone [repository-url]
cd humio-mcp
  1. Install dependencies:
npm install

or

pnpm install

or

yarn install
  1. Create a .env file in the root directory with your Humio configuration (this is only useful for dev/testing as the MCP client will provide the env variables anyway):
HUMIO_API_TOKEN=your_api_token
HUMIO_REQUEST_TIMEOUT_MS=30000
  1. Create config from the example config file
cp humio-query-config.example.json humio-query-config.json

Usage

Build the server:

npm run build

or

pnpm run build

or

yarn run build

Inspection

After building, you can inspect the server using the MCP Inspector:

npx @modelcontextprotocol/inspector node dist/index.js

Connect to the client. Sample config

"humioMCP": {
    "command": "node",
    "args": [
        "<absolute-path-to-server>/humio-mcp/dist/index.js"
    ],
    "type": "stdio",
    "env": {
        "HUMIO_API_TOKEN": "<HUMIO_API_TOKEN>",
        "HUMIO_REQUEST_TIMEOUT_MS": 3000
    }
}

Configuration File Format

The humio-query-config.json file defines the available queries for the server. Each entry in the array should follow the structure below:

FieldTypeRequiredDescription
namestringYesUnique name for the query configuration.
descriptionstringYesHuman-readable description of what the query does.
querystringYesThe Humio query string, can include template variables (e.g., {{variableName}}).
fieldsstring[]YesList of fields to extract from the query results.
variablesVariable[]NoList of variables required by the query. See below for the Variable format.
outputTemplatestringYesTemplate for formatting each result. Uses {{fieldName}} for interpolation.
joinStringstringYesString used to join multiple formatted results.

Variable Format

Each item in the variables array can be one of the following:

Scalar Variable
FieldTypeRequiredDescription
namestringYesName of the variable.
descriptionstringYesDescription of the variable.
type'string'|'number'|'boolean'YesType of the variable.
requiredbooleanYesWhether the variable is required.
Enum Variable
FieldTypeRequiredDescription
namestringYesName of the variable.
descriptionstringYesDescription of the variable.
type'enum'YesType of the variable (must be 'enum').
requiredbooleanYesWhether the variable is required.
enumOptionsstring[]YesAllowed values for the enum variable.
Example
[
  {
    "name": "criticalErrors",
    "description": "Finds critical errors for the banana team grouped by message and stack trace.",
    "query": "k8s.labels.team = banana | (severity = crit ) | groupBy([message, stack_trace])",
    "fields": ["message", "stack_trace", "_count"],
    "outputTemplate": "Error \"{{message}}\" occurred in total: {{_count}} times. The Stack trace is \n---{{stack_trace}}\n---\n\n",
    "joinString": "\n"
  },
  {
    "name": "projectOperationsByState",
    "description": "Groups operations by state for a given project in the banana team.",
    "query": "k8s.labels.team = banana | projectKey=\"{{projectKey}}\" | groupBy([fields.state])",
    "fields": ["fields.state", "_count"],
    "variables": [
      {
        "name": "projectKey",
        "description": "The project key to filter by.",
        "type": "string",
        "required": true
      }
    ],
    "outputTemplate": "state: {{fields.state}} - {{_count}} operations",
    "joinString": "\n"
  }
]

āš ļø Danger: Sensitive Information

Do NOT include any sensitive information in the fields field of your configuration.

The contents of the fields field are returned to the client and may be passed to a Large Language Model (LLM). Any sensitive data (such as API keys, passwords, personal information, or confidential business data) included here could be exposed.

Ensure that only non-sensitive, safe-to-share information is specified in the fields field of your config files.

āš ļø Warning: Timeout and Partial Results

If the configured timeout (HUMIO_REQUEST_TIMEOUT_MS) is reached during a query, the server will return the events collected up to that point. This means the results may be incomplete and might not capture all relevant events.

To reduce the risk of missing data, consider adjusting the timeout value according to your expected query size and network conditions.

Project Structure

humio-mcp/
ā”œā”€ā”€ src/
│   ā”œā”€ā”€ humio/                  # Humio-specific implementations
│   ā”œā”€ā”€ utils/                  # Utility functions
│   └── index.ts                # Main server entry point
ā”œā”€ā”€ dist/                       # Compiled JavaScript files
ā”œā”€ā”€ humio-query-config.json     # Configurations for available quries
ā”œā”€ā”€ package.json                # Project dependencies and scripts
└── tsconfig.json               # TypeScript configuration