mcplogview
Exposes configured log files as MCP tools, enabling agents to list, query, and follow logs from local and SSH sources.
README
mcplogview
General MCP logviewer server for exposing configured log files as MCP tools.
Configuration
Copy config/log-sources.example.json to config/log-sources.json and edit paths.
{
"transport": {
"mode": "stdio",
"host": "127.0.0.1",
"port": 3333,
"path": "/mcp"
},
"logging": {
"enabled": true,
"path": "scripts/logs/mcplogview-server.log",
"selfSourceId": "mcplogview-self",
"selfSourceLabel": "MCP Server Self Log"
},
"skillsDir": "config/log-skills",
"sources": [
{ "type": "local", "id": "app", "label": "App", "path": "/absolute/path/to/app.log", "hint": "Start here for API errors" },
{
"type": "ssh",
"id": "prod-api",
"label": "Prod API",
"host": "10.0.0.12",
"port": 22,
"user": "ubuntu",
"identityFile": "/Users/you/.ssh/id_ed25519",
"strictHostKeyChecking": false,
"path": "/var/log/myapp/api.log"
}
]
}
Transport modes:
stdio(default): MCP over stdin/stdouthttp: Streamable HTTP endpoint (http://host:port/path)https-dev: Streamable HTTPS endpoint with runtime-generated self-signed cert (or custom key/cert from config)
Logging:
- Server writes internal logs to
logging.pathwhenlogging.enabled=true. - By default, that self log is auto-added as a queryable source (
mcplogview-self). - If
logging.enabled=false, self-source is not auto-injected. - Request and tool errors are logged with stack traces to help diagnose HTTP
500issues.
Usage
npm install
npm run build
LOG_SOURCES_CONFIG=config/log-sources.json npm run dev
If LOG_SOURCES_CONFIG is not set, default path is config/log-sources.json.
SSH Notes
- SSH source uses non-interactive mode (
BatchMode=yes). identityFileis used automatically from config.strictHostKeyCheckingdefaults tofalsefor debug/dev convenience; settrueif needed.- Ensure your key permissions are correct and target host is reachable.
MCP Integration
Add the server command in your MCP client configuration:
{
"command": "node",
"args": ["/absolute/path/to/mcplogview/dist/src/cli.js"],
"env": { "LOG_SOURCES_CONFIG": "/absolute/path/to/mcplogview/config/log-sources.json" }
}
Tools
list_logs: Lists available configured logs, with optionalhint.get_log_skill: Returns usage skill (structured+renderedMarkdown) for a log source.read_log_chunk: Returns lines and next cursor.follow_log: Polls for new lines until timeout.
Recommended flow for agents:
list_logsget_log_skillfor selectedsourceIdread_log_chunk/follow_log
Skill Files
Optional file-based skill per source:
config/log-skills/<sourceId>.md
Format:
---
name: app-log
sourceId: app
version: 1
hint: Inspect this first for backend errors
tags: [api, backend, errors]
---
# App log guidance
Use this source during API incident triage.
Notes:
mcplogview-selfskill is built-in (server debug guidance), not loaded from file.- If a file is missing/invalid,
get_log_skillreturns a fallback skill with warnings.
HTTPS (Dev Mode)
When transport.mode is https-dev, mcplogview serves MCP over HTTPS. It uses custom key/cert files from config when provided, and falls back to runtime self-signed certificate generation when files are missing or invalid.
Configuration with custom key/cert
Provide your own key and cert paths in the transport config:
{
"transport": {
"mode": "https-dev",
"host": "127.0.0.1",
"port": 3333,
"path": "/mcp",
"httpsKey": "config/certs/key.pem",
"httpsCert": "config/certs/cert.pem"
},
"sources": [
{ "type": "local", "id": "demo", "label": "Demo Log", "path": "/tmp/mcplogview-demo.log" }
]
}
Fallback: auto-generated self-signed cert
When httpsKey/httpsCert are not provided, or when file loading fails, mcplogview generates a self-signed certificate at runtime:
- Algorithm: EC prime256v1
- Validity: 365 days
- Common Name:
localhost - Generated via
opensslCLI (requiresopensslinstalled)
The generated cert is temporary and recreated on each server restart. To generate your own persistent cert:
openssl req -x509 -newkey ec -pkeyopt ec_paramgen_curve:prime256v1 \
-keyout config/certs/key.pem -out config/certs/cert.pem \
-days 365 -nodes -subj /CN=localhost
Then reference them in your config as shown above.
Start server:
LOG_SOURCES_CONFIG=config/log-sources.json npm run dev
For clients/Inspector, use endpoint:
https://127.0.0.1:3333/mcp
MCP Inspector with HTTPS
When connecting MCP Inspector to an https-dev server:
- Start the MCP server with
transport.mode: "https-dev":
LOG_SOURCES_CONFIG=config/log-sources.json npm run dev
- Start MCP Inspector in a separate terminal (bypass self-signed cert check):
NODE_TLS_REJECT_UNAUTHORIZED="0" npx @modelcontextprotocol/inspector
-
In the Inspector UI, create a new connection:
- Transport: HTTP(S)
- URL:
https://127.0.0.1:3333/mcp
-
When the Inspector prompts about the self-signed certificate:
- Click "Allow" or "Proceed Anyway" to trust the cert
- The connection will be established
Note: The self-signed cert is only valid for localhost. If you need to connect from another machine, generate a cert with the target hostname or IP as the CN.
Quick Local Test (Generator + Inspector)
- Start demo log generator in terminal A:
./scripts/generate-demo-log.sh /tmp/mcplogview-demo.log 5
- Start MCP server (terminal B):
LOG_SOURCES_CONFIG=config/log-sources.json npm run dev
- In MCP Inspector, connect this server and call tools in order:
list_logs-> expect configured idsread_log_chunkwith{ "sourceId": "demo", "cursor": null, "maxLines": 20 }follow_logwith{ "sourceId": "demo", "cursor": "<cursor from previous call>", "maxLines": 20, "timeoutMs": 7000, "pollIntervalMs": 250 }
MCP Inspector Usage
Prerequisites:
npm installexecuted in this repo- built server (
npm run build) or direct TS run (npm run dev) - valid config file at
config/log-sources.json
- Install and start MCP Inspector
Recommended (no global install):
npx @modelcontextprotocol/inspector
Optional global install:
npm install -g @modelcontextprotocol/inspector
mcp-inspector
Inspector typically opens a local web UI (if not, open the URL shown in terminal, usually http://127.0.0.1:6274).
- Start the server
Stdio mode (default):
LOG_SOURCES_CONFIG=config/log-sources.json npm run dev
HTTP/HTTPS-dev mode: set "transport.mode" in config (http or https-dev), then start the same command above.
- Open MCP Inspector
Use the Inspector UI and create a new connection:
- For
stdio:- command:
node - args:
["/absolute/path/to/mcplogview/dist/src/cli.js"] - env:
{ "LOG_SOURCES_CONFIG": "/absolute/path/to/mcplogview/config/log-sources.json" }
- command:
- For
http:- URL:
http://127.0.0.1:3333/mcp(or your configuredhost:port/path)
- URL:
- For
https-dev:- URL:
https://127.0.0.1:3333/mcp - allow self-signed cert in Inspector/client settings
- URL:
- Call tools in recommended order
list_logsget_log_skillwith selectedsourceIdread_log_chunk(first page)follow_logusing returnedcursor
Example payloads:
{ "sourceId": "demo", "cursor": null, "maxLines": 20 }
{
"sourceId": "demo",
"cursor": "<cursor from read_log_chunk>",
"maxLines": 20,
"timeoutMs": 7000,
"pollIntervalMs": 250
}
- Troubleshooting
- Empty tool results: verify log file path exists and process has read access.
- Connection error on HTTPS-dev: trust/allow self-signed certificate.
500/tool failures: check server self-log (logging.path) and querymcplogview-self.- No config found: set
LOG_SOURCES_CONFIGexplicitly.
Portable Quickstart
Portable build uses Node.js SEA-oriented packaging scripts and produces artifacts in dist/portable.
npm run build
npm run portable:build
npm run portable:verify
npm run portable:checksums
Run with config override:
LOG_SOURCES_CONFIG=config/log-sources.json ./dist/portable/mcplogview-<version>-<platform>
Windows example:
$env:LOG_SOURCES_CONFIG='config/log-sources.json'
.\dist\portable\mcplogview-<version>-<platform>.exe
Raspberry Pi build from macOS (without building on Pi):
Prerequisites: Docker Desktop (or Docker Engine) must be installed and running, with linux/arm64 platform support enabled (Docker Desktop ships this by default via QEMU).
npm run portable:build:raspi
This runs a linux/arm64 Docker build (node:22-bookworm) and writes Raspberry-compatible artifacts to dist/portable/.
The container installs dependencies in its own /work folder, so your host node_modules stays untouched.
If LOG_SOURCES_CONFIG points to a missing file, mcplogview now auto-creates a minimal config with logging.debug=true and self-log source enabled.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.