Loki MCP Server

by ghrud92
MIT License
86
2
  • Linux
  • Apple

Integrations

  • Provides tools for querying Grafana Loki logs using LogQL, accessing label values and metadata, and analyzing log data with support for different output formats and filtering options.

Einfacher Loki MCP-Server

Der Loki MCP Server ist eine Model Context Protocol (MCP) -Schnittstelle zum Abfragen von Grafana Loki-Protokollen mithilfe von logcli . Der Server ermöglicht KI-Assistenten den direkten Zugriff auf und die Analyse von Protokolldaten von Loki.

Merkmale

  • Abfragen von Loki-Protokollen mit vollständiger LogQL-Unterstützung
  • Abrufen von Beschriftungswerten und Metadaten
  • Authentifizierungs- und Konfigurationsunterstützung über Umgebungsvariablen oder Konfigurationsdateien
  • Bietet formatierte Ergebnisse in verschiedenen Ausgabeformaten (Standard, Rohdaten, JSON-Zeilen)
  • Automatischer Fallback auf die HTTP-API, wenn logcli in der Umgebung nicht verfügbar ist

Voraussetzungen

  • Node.js v16 oder höher
  • Typoskript
  • (Optional) Grafana Loki logcli ist installiert und in Ihrem PATH zugänglich. Wenn logcli nicht verfügbar ist, verwendet der Server stattdessen automatisch die Loki HTTP API.
  • Zugriff auf eine Loki-Serverinstanz

Installation

Installation über Smithery

So installieren Sie Simple Loki MCP Server für Claude Desktop automatisch über Smithery :

npx -y @smithery/cli install @ghrud92/simple-loki-mcp --client claude

für MCP

{ "mcpServers": { "simple-loki": { "command": "npx", "args": ["-y", "simple-loki-mcp"], "env": { "LOKI_ADDR": "https://loki.sup.band" } } } }

npm

  1. Klonen Sie das Repository:
git clone https://github.com/ghrud92/loki-mcp.git cd loki-mcp
  1. Installieren Sie Abhängigkeiten:
npm install
  1. Erstellen Sie das Projekt:
npm run build

Verfügbare MCP-Tools

Abfrage-Loki

Abfrageprotokolle von Loki mit Filteroptionen.

Parameter:

  • query (erforderlich): Loki-Abfragezeichenfolge (LogQL)
  • from : Startzeitstempel (zB "2023-01-01T12:00:00Z")
  • to : Endzeitstempel (zB "2023-01-01T13:00:00Z")
  • limit : Maximale Anzahl der zurückzugebenden Protokolle
  • batch : Batchgröße für Abfrageergebnisse
  • output : Ausgabeformat („Standard“, „raw“ oder „jsonl“)
  • quiet : Abfragemetadaten unterdrücken
  • forward : Ergebnisse in chronologischer Reihenfolge anzeigen

Beschriftungswerte abrufen

Rufen Sie alle Werte für ein bestimmtes Label ab.

Parameter:

  • label (erforderlich): Bezeichnungsname, für den Werte abgerufen werden sollen

Etiketten abrufen

Alle verfügbaren Etiketten abrufen.

Keine Parameter erforderlich.

Konfiguration

Sie können den Loki-Zugriff folgendermaßen konfigurieren:

Umgebungsvariablen

  • LOKI_ADDR : Loki-Serveradresse (URL)
  • LOKI_USERNAME : Benutzername für die Basisauthentifizierung
  • LOKI_PASSWORD : Passwort für die Basisauthentifizierung
  • LOKI_TENANT_ID : Mandanten-ID für Loki mit mehreren Mandanten
  • LOKI_BEARER_TOKEN : Bearer-Token zur Authentifizierung
  • LOKI_BEARER_TOKEN_FILE : Datei mit dem Inhabertoken
  • LOKI_CA_FILE : Benutzerdefinierte CA-Datei für TLS
  • LOKI_CERT_FILE : Client-Zertifikatsdatei für TLS
  • LOKI_KEY_FILE : Client-Schlüsseldatei für TLS
  • LOKI_ORG_ID : Organisations-ID für Multi-Org-Setups
  • LOKI_TLS_SKIP_VERIFY : TLS-Verifizierung überspringen („true“ oder „false“)
  • LOKI_CONFIG_PATH : Benutzerdefinierter Pfad zur Konfigurationsdatei
  • DEBUG : Debug-Protokollierung aktivieren

Hinweis : Wenn der Client den HTTP-API-Modus verwendet (wenn logcli nicht verfügbar ist), werden dieselben Konfigurationsparameter zur Authentifizierung und Verbindung mit dem Loki-Server verwendet.

Konfigurationsdateien

Alternativ können Sie an einem dieser Speicherorte eine Datei logcli-config.yaml erstellen:

  • Benutzerdefinierter Pfad, angegeben durch LOKI_CONFIG_PATH
  • Aktuelles Arbeitsverzeichnis
  • Ihr Home-Verzeichnis ( ~/.logcli-config.yaml )

Beispielkonfigurationsdatei:

addr: https://loki.example.com username: user password: pass tenant_id: mytenant

Verwendung

Starten Sie den Server:

npm start

Für die Entwicklung:

npm run dev

Implementierungsdetails

Automatischer Fallback auf HTTP-API

Der Server prüft automatisch, ob logcli installiert und in der Umgebung verfügbar ist:

  1. Wenn logcli verfügbar ist, wird es für alle Abfragen verwendet und bietet die volle Funktionalität des CLI-Tools
  2. Wenn logcli nicht verfügbar ist, greift der Server automatisch auf die Loki-HTTP-API zurück:
    • Es ist keine zusätzliche Konfiguration erforderlich
    • Für die HTTP-API werden die gleichen Authentifizierungsparameter verwendet
    • Die Antwortformatierung stimmt mit der CLI-Ausgabe überein
    • Das Standardlimit von 1000 Protokollen pro Abfrage gilt in beiden Modi

Diese automatische Erkennung stellt sicher, dass der Server in verschiedenen Umgebungen ohne manuelle Konfiguration reibungslos funktioniert.

Entwicklung

# Run linter npm run lint # Fix linting issues npm run lint:fix # Run tests npm run test

Lizenz

Dieses Projekt ist unter der MIT-Lizenz lizenziert – Einzelheiten finden Sie in der Datei LICENSE.md .

You must be authenticated.

A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

remote-capable server

The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.

Eine MCP-Schnittstelle, die es KI-Assistenten ermöglicht, Grafana Loki-Protokolle mithilfe von LogQL abzufragen und zu analysieren, mit Unterstützung für Authentifizierung und verschiedene Ausgabeformate.

  1. Merkmale
    1. Voraussetzungen
      1. Installation
        1. Installation über Smithery
        2. für MCP
        3. npm
      2. Verfügbare MCP-Tools
        1. Abfrage-Loki
        2. Beschriftungswerte abrufen
        3. Etiketten abrufen
      3. Konfiguration
        1. Umgebungsvariablen
        2. Konfigurationsdateien
      4. Verwendung
        1. Implementierungsdetails
          1. Automatischer Fallback auf HTTP-API
        2. Entwicklung
          1. Lizenz

            Related MCP Servers

            • -
              security
              A
              license
              -
              quality
              A proxy server that enables AI assistants to run and interact with command-line applications like Expo through the Model Context Protocol (MCP), capturing logs and allowing keypress forwarding.
              Last updated -
              12
              6
              TypeScript
              MIT License
            • -
              security
              F
              license
              -
              quality
              An MCP server that connects to Backlog API, providing functionality to search, retrieve, and update issues through natural language commands.
              Last updated -
              24
              1
              JavaScript
              • Apple
            • -
              security
              A
              license
              -
              quality
              An MCP server that allows AI assistants to interact with Foundry datasets, ontology objects, and functions through natural language queries and commands.
              Last updated -
              2
              Python
              MIT License

            View all related MCP servers

            ID: e3vo22yclf