MCP server for Zabbix API — daily brief, problems, hosts, items
Project description
zapi-mcp
English | 日本語
MCP (Model Context Protocol) server for the Zabbix API.
Built for network operations: a single daily_brief call summarizes active
problems plus site-specific categories (DHCP pool usage, SNAT session usage,
core-network problems, …), and individual tools query problems, hosts, and item
values. Organization-specific tags live in a config file, not the code, so the
server stays generic.
Version-adaptive auth: works against Zabbix 6.0 LTS (user + auth field) and
forward-compatible with 6.4 / 7.0 (username + Authorization: Bearer).
Features
| Tool | Description |
|---|---|
daily_brief |
Morning patrol: active problems (Warning+) plus one section per configured category |
get_problems |
Active problems by severity and tag, newest-first with age; header shows the true total (showing N of TOTAL when capped); output includes eventid |
get_hosts |
List hosts filtered by role/tag/group, with IP and tags |
get_host_items |
Current item values for a host (server-side host filter) |
acknowledge_problem |
Acknowledge problems and add a message (does not close them) |
Setup
# uv
uv pip install zapi-mcp
# pip
pip install zapi-mcp
Or from source:
git clone https://github.com/shigechika/zapi-mcp.git
cd zapi-mcp
# uv
uv sync
# pip
pip install -e .
Configuration
Set the following environment variables:
| Variable | Description | Default |
|---|---|---|
ZABBIX_URL |
Zabbix base URL (e.g. https://zabbix.example.com); /api_jsonrpc.php is appended if absent |
required |
ZABBIX_USER |
Zabbix API user | required |
ZABBIX_PASSWORD |
Zabbix API password | required |
ZABBIX_CATEGORIES_INI |
Path to a categories INI file for daily_brief (optional) |
— |
ZABBIX_BRIEF_RECENT_HOURS |
daily_brief "recent" window in hours; problems older than this are folded to a count |
24 |
ZABBIX_BRIEF_PROBLEM_LIMIT |
Max active problems daily_brief fetches per call before counting the rest |
1000 |
The API user needs read permission for the host groups you query, plus
acknowledge permission if you use acknowledge_problem.
Active problems in daily_brief
Problems are grouped by severity and listed newest-first, each annotated with
its age (e.g. 3h ago). Problems older than the recent window
(ZABBIX_BRIEF_RECENT_HOURS, default 24h) are folded to a single
… and N older (stale; oldest …) line — so a backlog of alerts that Zabbix
keeps active because their recovery is never auto-confirmed (ICMP ping down, RDP
down, …) doesn't bury what just happened. Section headers carry the true total
and show showing N of TOTAL when the fetch is capped, never a silent truncation.
Categories for daily_brief (optional)
daily_brief always lists active problems. To add site-specific sections —
DHCP pool exhaustion, SNAT session usage, core-network problems — point
ZABBIX_CATEGORIES_INI at an INI file. Each [section] is one category:
[dhcp]
name = DHCP Pool Usage
tag = dhcp-pool-usage ; Zabbix host tag identifying the group
item_key = usage ; report current values for this exact item key
threshold = 80 ; flag values >= this
[snat]
name = SNAT Session Pool
tag = snat-pool-usage
item_key_search = .usage ; substring match (catches pool.node0.usage etc.)
threshold = 80
[core]
name = Core Network
tag = role
tag_value = main ; tag must equal this value
; no item key -> report active problems instead
tag(required): host tag identifying the category. Withtag_value, the tag must equal it (Equal); without, any host carrying the tag matches (Exists).item_key/item_key_search: when either is set, the section reports current item values sorted high-to-low.item_keymatches the key exactly; useitem_key_searchfor keys that embed an id (e.g..usagecatchespool.node0.usage). When neither is set, it reports active problems for the tag.threshold: optional; values at or above it are flagged.
See categories.ini.example. When the variable is
unset or the file is missing, daily_brief reports active problems only.
Usage
Claude Code
Add to .mcp.json:
{
"mcpServers": {
"zapi-mcp": {
"type": "stdio",
"command": "zapi-mcp",
"env": {
"ZABBIX_URL": "https://zabbix.example.com",
"ZABBIX_USER": "api-user",
"ZABBIX_PASSWORD": "",
"ZABBIX_CATEGORIES_INI": "/path/to/categories.ini"
}
}
}
}
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"zapi-mcp": {
"command": "zapi-mcp",
"env": {
"ZABBIX_URL": "https://zabbix.example.com",
"ZABBIX_USER": "api-user",
"ZABBIX_PASSWORD": ""
}
}
}
}
Direct Execution
export ZABBIX_URL=https://zabbix.example.com
export ZABBIX_USER=api-user
export ZABBIX_PASSWORD=your-password
zapi-mcp
CLI Options
zapi-mcp --version # Print version and exit
zapi-mcp --check # Verify environment variables and authentication, then exit
zapi-mcp --brief # Print the daily_brief to stdout and exit (handy for cron)
zapi-mcp # Start MCP server (STDIO, default)
--check exit codes: 0 success, 1 config error, 2 auth/connection error.
Development
git clone https://github.com/shigechika/zapi-mcp.git
cd zapi-mcp
# uv
uv sync --dev
uv run pytest -v
uv run ruff check .
# pip
python3 -m venv .venv
.venv/bin/pip install -e . && .venv/bin/pip install pytest pytest-cov respx ruff
.venv/bin/pytest -v
.venv/bin/ruff check .
Releasing
Releases are automated with release-please.
Merging Conventional Commits (feat:, fix:, …)
to main keeps a release PR open with the next version and changelog. Merging
that PR tags vX.Y.Z and publishes a GitHub Release, whose release: published
event triggers the release workflow to build and publish to PyPI and the MCP
Registry. release-please owns the version in zapi_mcp/__init__.py and
server.json (do not bump them by hand).
[!IMPORTANT] The release-please workflow should be given a repository secret
RELEASE_PLEASE_TOKEN(a PAT withcontents: write+pull-requests: write). The defaultGITHUB_TOKENcannot create the Release that triggers the downstreamreleaseworkflow (GitHub blocks workflow runs triggered byGITHUB_TOKEN), so without the PAT nothing gets published. The workflow falls back toGITHUB_TOKENwhen the secret is unset so PR CI keeps working on forks.
Roadmap
- Streamable HTTP transport + OAuth2 for remote / mobile use
- Visual rendering of key metrics
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zapi_mcp-0.2.0.tar.gz.
File metadata
- Download URL: zapi_mcp-0.2.0.tar.gz
- Upload date:
- Size: 24.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f57e5065197983c16f74590e552397f0991f5b2bf4d876fccabdcaaf6fe6babf
|
|
| MD5 |
31463b90bfe074be08b92b609ca87b95
|
|
| BLAKE2b-256 |
e6a91812f5d2c5d6b598ddfa3dad671653a9db0cdc0ab0ac5f334865b471716f
|
Provenance
The following attestation bundles were made for zapi_mcp-0.2.0.tar.gz:
Publisher:
release.yml on shigechika/zapi-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zapi_mcp-0.2.0.tar.gz -
Subject digest:
f57e5065197983c16f74590e552397f0991f5b2bf4d876fccabdcaaf6fe6babf - Sigstore transparency entry: 1690749670
- Sigstore integration time:
-
Permalink:
shigechika/zapi-mcp@9cd7d8b6e59647d5ab6e7e84b69c5d53b70c5cf7 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/shigechika
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9cd7d8b6e59647d5ab6e7e84b69c5d53b70c5cf7 -
Trigger Event:
release
-
Statement type:
File details
Details for the file zapi_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: zapi_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 16.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d192a8a5b94aac4c1c760685329a729f1b1920aa755a47fd408e95b162724480
|
|
| MD5 |
4217872600665c2be4fe6ba63b8d4a6a
|
|
| BLAKE2b-256 |
e11a5b7fd87a6070475d6d8a7468cbb72311d3e536aa9118a75acd315bba5ad6
|
Provenance
The following attestation bundles were made for zapi_mcp-0.2.0-py3-none-any.whl:
Publisher:
release.yml on shigechika/zapi-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zapi_mcp-0.2.0-py3-none-any.whl -
Subject digest:
d192a8a5b94aac4c1c760685329a729f1b1920aa755a47fd408e95b162724480 - Sigstore transparency entry: 1690749690
- Sigstore integration time:
-
Permalink:
shigechika/zapi-mcp@9cd7d8b6e59647d5ab6e7e84b69c5d53b70c5cf7 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/shigechika
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9cd7d8b6e59647d5ab6e7e84b69c5d53b70c5cf7 -
Trigger Event:
release
-
Statement type: