mcp-dns-insights
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-dns-insightsAnalyze my DNS traffic from the last 24 hours"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-dns-insights
Capture the DNS queries leaving your Mac and serve them to Claude over the Model Context Protocol so Claude can analyse your traffic patterns and hand back a structured JSON overview.
It answers questions like:
Which domains does my machine talk to the most?
How much of my traffic is advertising, analytics, or telemetry?
When am I busiest, and were there any unusual bursts of activity?
How it works
┌────────────┐ ┌──────────────┐ ┌───────────────┐ ┌────────┐
│ tcpdump │ --> │ capture │ --> │ SQLite db │ <-- │ MCP │ <── Claude
│ (port 53) │ │ daemon │ │ (dns.db) │ │ server │
└────────────┘ └──────────────┘ └───────────────┘ └────────┘A capture daemon runs
tcpdump, parses each DNS question off the wire, and appends it to a local SQLite database.An MCP server exposes read-only tools over stdio. Claude calls
analyze_patterns(and friends) and receives JSON it can summarise.
The two halves are decoupled through the database: capture is a single writer, the server is a read-only consumer.
Related MCP server: AynOps
Install
Requires Python 3.10+ and the tcpdump that ships with macOS.
git clone https://github.com/luke-nielsen/mcp-dns-insights.git
cd mcp-dns-insights
python3 -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]"Usage
1. Capture DNS traffic
Packet capture needs root, so run the daemon under sudo:
sudo -E mcp-dns-insights captureLeave it running in the background (or install it as a launchd job — see below).
Use -i en0 to pin a specific interface; the default any captures all of them.
2. Inspect from the terminal
mcp-dns-insights stats --hours 24 # human-readable summary
mcp-dns-insights stats --hours 24 --json
mcp-dns-insights info # database location & span3. Connect it to Claude
The server speaks MCP over stdio. Register it with Claude Code:
claude mcp add dns-insights -- mcp-dns-insights serveor add it to your MCP host config manually:
{
"mcpServers": {
"dns-insights": {
"command": "mcp-dns-insights",
"args": ["serve"]
}
}
}Then ask Claude: "Analyse my DNS traffic from the last 24 hours and tell me what's noteworthy."
MCP tools
Tool | Purpose |
| Full JSON overview: top domains, categories, temporal, notes. |
| The most recent queries as a JSON list. |
| Find queries whose hostname matches a substring. |
| Database path, size, and time span. |
Shape of analyze_patterns
{
"summary": { "total_queries": 4213, "unique_hostnames": 612, "unique_domains": 241, "window": { ... } },
"top_hostnames": [ { "name": "api.github.com", "count": 88 }, ... ],
"top_domains": [ { "name": "github.com", "count": 140 }, ... ],
"query_types": { "A": 3100, "AAAA": 980, "HTTPS": 133 },
"clients": [ { "name": "192.168.1.10", "count": 4100 } ],
"resolvers": [ { "name": "1.1.1.1", "count": 4213 } ],
"categories": { "analytics": 210, "advertising": 95, "cdn": 540 },
"flagged_domains": [ { "domain": "doubleclick.net", "category": "advertising", "count": 60 } ],
"temporal": { "by_hour": { ... }, "busiest_hour": { ... }, "peak_queries_per_minute": 47 },
"observations": [ "github.com accounts for 140 queries (3% of the total).", ... ]
}Run as a launchd job (optional)
Create ~/Library/LaunchAgents/us.radiusgroup.mcp-dns-insights.plist (capture
needs root, so a LaunchDaemon in /Library/LaunchDaemons is the better fit):
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key><string>us.radiusgroup.mcp-dns-insights</string>
<key>ProgramArguments</key>
<array>
<string>/path/to/.venv/bin/mcp-dns-insights</string>
<string>capture</string>
</array>
<key>RunAtLoad</key><true/>
<key>KeepAlive</key><true/>
</dict>
</plist>sudo cp us.radiusgroup.mcp-dns-insights.plist /Library/LaunchDaemons/
sudo launchctl load /Library/LaunchDaemons/us.radiusgroup.mcp-dns-insights.plistConfiguration
All settings have sensible defaults and can be overridden via the environment:
Variable | Default |
|
|
| data directory (overrides the default location) |
|
|
|
|
|
|
|
|
|
|
Privacy
The database contains a record of every hostname your Mac looked up — that is
sensitive. It is stored only on your machine and is never transmitted
anywhere except to the local MCP server you explicitly connect to Claude. The
.gitignore excludes *.db so capture data is never committed.
Note: queries answered by DNS-over-HTTPS/TLS (e.g. some browsers' built-in secure DNS) are encrypted and will not be visible to a port-53 capture.
Development
pip install -e ".[dev]"
pytest # run the test suite
ruff check . # lintLicense
MIT — see LICENSE.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/luke-nielsen/mcp-dns-insights'
If you have feedback or need assistance with the MCP directory API, please join our Discord server