meteoswiss-mcp
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., "@meteoswiss-mcpWhat's the current weather in Zurich?"
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.
meteoswiss-mcp
MCP Server für Schweizer Wetter- und Klimadaten von MeteoSwiss.
Verbindet KI-Modelle mit dem SwissMetNet-Messnetz (160+ Stationen, 10-Minuten-Intervall), MeteoSwiss ICON-CH1/CH2-EPS Prognosen und Klimanormwerten 1991–2020. Teil des swiss-public-data-mcp Portfolios.
Demo-Abfrage (Anker-Beispiel)
Wie geeignet ist nächster Mittwoch für den Sporttag beim Schulhaus Leutschenbach?→ meteo_school_check(location="Zürich Oerlikon", activity="Sporttag") liefert eine 🟢/🟡/🔴-Ampel für jeden Tag der nächsten Woche – direkt aus dem MeteoSwiss ICON-Modell.
Kombiniert mit swiss-environment-mcp:
Wie war Luftqualität und Wetter beim Schulhaus Leutschenbach gestern?→ meteo_current(station='REH') + env_nabel_current(station='ZUE') = vollständiges Umweltbild.
→ More use cases by audience →
Tools (6)
Tool | Beschreibung | Datenquelle |
| SwissMetNet-Stationen auflisten (kanton-filterbar) | Eingebettet |
| Aktuelle 10-min-Beobachtungen einer Station | BGDI STAC API |
| 1–16 Tage Prognose für Ort oder Koordinaten | Open-Meteo / MeteoSwiss ICON |
| 🟢/🟡/🔴 Ampel für Schulveranstaltungen im Freien | Open-Meteo / MeteoSwiss ICON |
| Monatliche Klimanormwerte 1991–2020 | Eingebettet (KLO, SMA, BER, LUG, GVE) |
| Aktuelle Wetterwarnungen & Links | opendata.swiss + Links |
Tool Annotations (MCP-Hints)
Alle Tools tragen explizite MCP-Annotations — relevant für Client-Approval-UI und Sicherheitsentscheide des LLM.
Tool |
|
|
|
|
| ✅ | ✗ | ✅ | ✗ (kuratierte Liste) |
| ✅ | ✗ | ✗ (Live-Daten) | ✅ (Upstream-STAC) |
| ✅ | ✗ | ✗ (Live-Daten) | ✅ (Upstream-Open-Meteo) |
| ✅ | ✗ | ✗ (Live-Daten) | ✅ (Geocoding + Forecast) |
| ✅ | ✗ | ✅ | ✗ (eingebettete Normwerte) |
| ✅ | ✗ | ✗ (Live-Daten) | ✅ (opendata.swiss) |
Lese-Regeln: alle 6 Tools sind readOnly + non-destructive — der Server kann grundsätzlich nichts schreiben oder löschen. idempotentHint=False markiert Tools, die je nach Zeitpunkt unterschiedliche Werte liefern.
MCP Protocol Version
Aspekt | Wert |
Getestete Spec-Versionen |
|
FastMCP-SDK-Version | siehe |
Update-Policy | Dependabot bewacht |
→ Vollständige Roadmap & Update-Strategie: docs/roadmap.md
Schnellstart
Claude Desktop
{
"mcpServers": {
"meteoswiss": {
"command": "uvx",
"args": ["meteoswiss-mcp"]
}
}
}Claude Desktop (lokale Entwicklung)
{
"mcpServers": {
"meteoswiss": {
"command": "uv",
"args": ["run", "--directory", "/pfad/zu/meteoswiss-mcp", "meteoswiss-mcp"]
}
}
}Cloud / Render.com (Streamable HTTP)
Konfiguration via ENV-Variablen (CLI-Flags --http / --port N funktionieren weiterhin als Override):
Variable | Default | Bedeutung |
|
|
|
|
| Bind-Address — lokal nie ändern |
|
| Port |
| unset | Muss auf |
|
|
|
| unset | Komma-separierte Liste erlaubter Origins für CORS. Leer = CORS deaktiviert (same-origin only). |
| unset | Wenn gesetzt: alle Requests ausser |
|
|
|
| unset | Wenn gesetzt + |
|
| Service-Name in den OTel-Resources |
|
|
|
|
| TTL in Sekunden für STAC-SMN-Beobachtungen (default 5 min) |
|
| TTL für ICON-Prognosen (default 10 min) |
|
| TTL für Geocoding-Lookups (default 1 h) |
|
| TTL für opendata.swiss-Katalog (default 1 h) |
|
| TTL für strukturierte Warnings-API (default 5 min) |
| unset | Pfad auf JSON-Datei mit zusätzlichen Klimanormwerten — siehe |
| unset | URL einer strukturierten MeteoSwiss-Warnings-API. Host muss in der Egress-Allow-List stehen. Schema-tolerant (GeoJSON |
| unset | URL-Template für Runtime-Lookup von Klimanormwerten (für Stationen ohne eingebettete oder JSON-Werte). Tokens: |
# Lokaler Test (sicher, nur loopback)
MCP_TRANSPORT=streamable-http meteoswiss-mcp
# Container / Render
MCP_TRANSPORT=streamable-http MCP_HOST=0.0.0.0 MCP_ALLOW_ANY_HOST=1 meteoswiss-mcpDocker / Render
Das Repo enthält ein produktionsfertiges Multi-Stage-Dockerfile (non-root user, HEALTHCHECK) und ein render.yaml-Blueprint:
# Lokal bauen + testen
docker build -t meteoswiss-mcp .
docker run --rm -p 8000:8000 meteoswiss-mcp
curl http://127.0.0.1:8000/health # → {"status":"ok","service":"meteoswiss-mcp"}Auf Render: «New → Blueprint» → Repo auswählen. Defaults (Plan starter, Frankfurt, single-instance) sind im render.yaml vorgegeben.
Wichtig: numInstances: 1 ist bewusst gesetzt — Sticky-Session-Routing für Multi-Replica (Audit SCALE-002/003) ist noch nicht implementiert.
Structured Logging
Alle Tool-Invocations, Upstream-Failures und Egress-Blocks werden als JSON-Events auf stderr ausgegeben (stdio-Transport-sicher). Beispiel:
{"tool": "meteo_forecast", "days": 7, "has_coords": false, "event": "tool_invoked", "level": "info", "timestamp": "2026-05-20T07:00:00Z"}
{"tool": "meteo_forecast", "endpoint": "geocoding", "error_type": "HTTPStatusError", "event": "upstream_failed", "level": "warning", "timestamp": "..."}
{"url": "https://evil.example.com/", "method": "GET", "reason": "host not in allow-list", "event": "egress_blocked", "level": "warning", "timestamp": "..."}HTTP-Modus Sicherheit
MCP_HOSTdefaultet bewusst auf127.0.0.1, damit--httpauf dem Dev-Laptop nicht versehentlich ins lokale Subnetz exponiert ist (Audit-Finding SEC-016).Alle ausgehenden HTTP-Calls (auch Redirect-Follows) werden gegen eine Allow-List validiert:
data.geo.admin.ch,api.open-meteo.com,geocoding-api.open-meteo.com,opendata.swiss. Andere Hosts und IP-Literale (insb.169.254.169.254, RFC1918) werden mitEgressBlockedabgelehnt (SEC-004 / SEC-021).CORS: per Default deaktiviert (same-origin only). Browser-Clients (z.B. claude.ai Web) brauchen
MCP_ALLOWED_ORIGINS=<csv>— derMcp-Session-Id-Header ist dann automatisch inAccess-Control-Expose-Headers(SDK-004).API-Key-Auth: per Default deaktiviert. Im produktiven HTTP-Setup unbedingt
MCP_API_KEY=<random>setzen — Requests ohne gültigenX-API-KeyoderAuthorization: Bearer …werden mit 401 abgelehnt (SEC-009 / SEC-013)./healthbleibt für Container-Health-Probes offen.
Beispiel: produktiver HTTP-Stack
# 32 Bytes Zufall als Auth-Key
export MCP_API_KEY=$(python -c "import secrets; print(secrets.token_urlsafe(32))")
MCP_TRANSPORT=streamable-http \
MCP_HOST=0.0.0.0 \
MCP_ALLOW_ANY_HOST=1 \
MCP_ALLOWED_ORIGINS=https://app.example.com \
MCP_API_KEY="$MCP_API_KEY" \
meteoswiss-mcpBeispiel-Abfragen
Schulplanung
Welche Tage eignen sich nächste Woche für einen Sporttag in Zürich?
→ meteo_school_check(location="Zürich", activity="Sporttag")
Wie wird das Wetter am Schulhaus Leutschenbach am Freitag?
→ meteo_forecast(location="Zürich Oerlikon", days=5)
Zeig mir aktuelle Messwerte der nächsten MeteoSwiss-Station zu Zürich-Schwamendingen.
→ meteo_current(station="REH")Klimavergleich
Wie viel Regen fällt normalerweise im Juni in Zürich?
→ meteo_climate_normals(station="KLO")
Ist Lugano wirklich deutlich sonniger als Zürich? Zeig mir die Jahreswerte.
→ meteo_climate_normals(station="LUG") + meteo_climate_normals(station="SMA")Infrastruktur & Umwelt
Gibt es aktuell Wetterwarnungen für den Kanton Zürich?
→ meteo_warnings(canton="ZH")
Zeig mir eine 10-Tage-Prognose für die Schulanlage Heerenschürli mit Stundenwerten.
→ meteo_forecast(location="Sportanlage Heerenschürli Zürich", days=10, hourly=True)Architektur
Claude Desktop / KI-Agent
│
│ MCP (stdio / Streamable HTTP)
▼
meteoswiss-mcp (FastMCP)
│
├── meteo_stations ──────────────── [eingebettet: ~20 SMN-Stationen]
│
├── meteo_current ───────────────── BGDI STAC API
│ data.geo.admin.ch/api/stac/v1
│ Collection: ch.meteoschweiz.ogd-smn
│
├── meteo_forecast ──────────────── Open-Meteo
├── meteo_school_check ──────────── api.open-meteo.com/v1/meteoswiss
│ (MeteoSwiss ICON-CH1/CH2-EPS, 1–2 km)
│
├── meteo_climate_normals ───────── [eingebettet: Normwerte 1991–2020]
│
└── meteo_warnings ──────────────── opendata.swiss CKAN + LinksDatenquellen
Quelle | URL | Lizenz |
BGDI STAC API (MeteoSwiss OGD) |
| CC BY 4.0 |
Open-Meteo (MeteoSwiss ICON) |
| CC BY 4.0 |
Open-Meteo Geocoding |
| CC BY 4.0 |
opendata.swiss CKAN |
| CC BY 4.0 |
Safety & Limits
Aspect | Details |
Access | Read-only ( |
Personal data | No personal data — all sources are aggregated, publicly available open data |
Rate limits | Built-in per-query caps: max 50 results per API call, 30 s timeout |
Authentication | No API keys required — all data sources are publicly accessible |
Licenses | All data under CC BY 4.0 (MeteoSwiss Open Government Data) |
Terms of Service | Subject to ToS of the respective data sources: MeteoSwiss OGD, Open-Meteo, opendata.swiss |
Bekannte Einschränkungen
ID | Tool | Beschreibung |
BUG-01 |
| STAC Asset-Struktur kann je nach Station variieren; Fallback zu direktem Link implementiert |
LIM-01 |
| Nur 5 Stationen eingebettet (KLO, SMA, BER, LUG, GVE); restliche via opendata.swiss-Link |
LIM-02 |
| Direkte Warnings-REST-API geplant ab Q2 2026 (MeteoSwiss OGD Phase 2); aktuell Links + CAP |
LIM-03 |
| Zeigt 10-min-Werte in UTC; keine automatische Umrechnung in lokale Zeit |
Synergien im Portfolio
meteoswiss-mcp
│
├── swiss-environment-mcp Kombiniere Wetter + Luftqualität (NABEL)
│ «Wie war Wetter UND Luft beim Schulhaus Leutschenbach?»
│
└── zurich-opendata-mcp Schulhausstandorte → Wetterprognose
«Welche Schulen in Zürich haben Sporttag-Wetter?»Testing
# Unit-Tests (kein Netzwerk)
PYTHONPATH=src pytest tests/ -m "not live" -v
# Live-Tests (echte APIs)
PYTHONPATH=src pytest tests/ -m live -v
# Linting
ruff check src/ tests/Entwicklung
git clone https://github.com/malkreide/meteoswiss-mcp
cd meteoswiss-mcp
pip install -e ".[dev]"MCP Inspector (lokaler Test)
PYTHONPATH=src npx @modelcontextprotocol/inspector python -m meteoswiss_mcp.serverLizenz
MIT License – siehe LICENSE.
Quelldaten: MeteoSwiss Open Government Data (CC BY 4.0). Bei Nutzung der Daten: Quelle: MeteoSchweiz angeben.
Verwandte Server
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/malkreide/meteoswiss-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server