feat: IP-Watcher – automatischer Neustart bei IP-Wechsel

This commit is contained in:
scriptos
2026-03-26 21:09:23 +01:00
parent 7539e18a46
commit 7bf847d31c
6 changed files with 99 additions and 0 deletions
+6
View File
@@ -117,3 +117,9 @@ XASECO_DB_PASSWORD="4KpL8mWnR3xYvBq"
# Dedimania-Nation (3-Zeichen IOC-Code, z.B. DEU, AUT, CHE)
# Server-Login und -Passwort werden automatisch aus SERVER_LOGIN / SERVER_LOGIN_PASSWORD übernommen.
XASECO_DEDIMANIA_NATION=DEU
# --- IP-Watcher ---
# Der IP-Watcher überwacht die ausgehende öffentliche IP des Containers und startet tmserver
# automatisch neu, wenn sich die IP ändert damit er sich beim Masterserver neu registriert.
# Intervall in Sekunden, in dem die IP geprüft wird (Standard: 300 = 5 Minuten).
IP_WATCHER_INTERVAL=300
+31
View File
@@ -0,0 +1,31 @@
#!/bin/sh
# Überwacht die ausgehende öffentliche IP des Containers und startet tmserver neu,
# wenn sich die IP ändert, damit er sich mit der neuen IP beim Masterserver registriert.
set -e
apk add --no-cache curl docker-cli > /dev/null 2>&1
set +e
INTERVAL="${IP_WATCHER_INTERVAL:-300}"
LAST_IP=""
echo "[ip-watcher] Gestartet. Prüfintervall: ${INTERVAL}s"
while true; do
CURRENT_IP=$(curl -s --max-time 10 https://api.ipify.org 2>/dev/null)
if [ -z "$CURRENT_IP" ]; then
echo "[ip-watcher] Öffentliche IP konnte nicht ermittelt werden. Neuer Versuch in ${INTERVAL}s."
elif [ "$CURRENT_IP" != "$LAST_IP" ]; then
if [ -n "$LAST_IP" ]; then
echo "[ip-watcher] IP geändert: ${LAST_IP} -> ${CURRENT_IP}. Starte tmserver neu..."
docker restart tmserver
echo "[ip-watcher] tmserver erfolgreich neu gestartet."
else
echo "[ip-watcher] Initiale öffentliche IP: ${CURRENT_IP}"
fi
LAST_IP="$CURRENT_IP"
fi
sleep "$INTERVAL"
done
+16
View File
@@ -53,6 +53,22 @@ services:
tmserver_net:
ipv4_address: 172.20.60.11
ip-watcher:
image: alpine:3.21
container_name: tmserver-ip-watcher
restart: unless-stopped
depends_on:
- tmserver
command: ["/bin/sh", "/opt/WatchPublicIP.sh"]
env_file:
- .env
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ./assets/bin/WatchPublicIP.sh:/opt/WatchPublicIP.sh:ro
networks:
tmserver_net:
ipv4_address: 172.20.60.12
networks:
tmserver_net:
name: tmserver.dockernetwork.local
+2
View File
@@ -15,6 +15,7 @@
| [AdminServ](adminserv.md) | Einrichtung der Server-Verwaltungsoberfläche |
| [RemoteCP](remotecp.md) | Alternative Server-Verwaltungsoberfläche (inkl. Mods/Skins) |
| [XAseco](xaseco.md) | Server-Controller für Rekorde, Karma und Jukebox |
| [IP-Watcher](ip-watcher.md) | Automatischer Neustart bei IP-Wechsel |
| [Ports](ports.md) | Freigegebene Ports und deren Verwendung |
## Projektstruktur
@@ -26,6 +27,7 @@
│ │ ├── remoteCP_v4.0.3.5.zip # RemoteCP Web-UI
│ │ ├── RunTrackmaniaServer.sh # Container-Startscript
│ │ ├── TrackmaniaServer_2011-02-21.zip # Trackmania Server Binary
│ │ ├── WatchPublicIP.sh # IP-Watcher-Script
│ │ └── xaseco_v1.16.zip # XAseco Server-Controller
│ ├── config/
│ │ ├── adminserv/ # AdminServ-Konfiguration
+36
View File
@@ -0,0 +1,36 @@
# IP-Watcher
Der IP-Watcher ist ein Service (`tmserver-ip-watcher`), der automatisch die öffentliche IP des Hosts überwacht und den `tmserver`-Container neu startet, sobald sich die IP ändert.
## Hintergrund
Trackmania-Server registrieren sich beim Start mit ihrer aktuellen öffentlichen IP beim Nadeo-Masterserver. Bei dynamischen IP-Adressen kann sich diese IP jederzeit ändern der Server bleibt dann unter der veralteten IP registriert und ist für Spieler nicht mehr erreichbar.
Der IP-Watcher erkennt solche IP-Wechsel automatisch und startet `tmserver` neu, sodass er sich mit der neuen IP beim Masterserver neu registriert.
## Funktion
Der Watcher läuft als eigener Docker-Container und:
1. Prüft regelmäßig die ausgehende öffentliche IP (identisch mit der IP, die auch `tmserver` nach außen verwendet)
2. Erkennt Abweichungen zur zuletzt bekannten IP
3. Startet `tmserver` über den Docker-Socket automatisch neu
## Konfiguration
| Variable | Beschreibung | Standard |
|----------|-------------|----------|
| `IP_WATCHER_INTERVAL` | Prüfintervall in Sekunden | `300` (5 Minuten) |
## Deaktivieren
Um den IP-Watcher zu deaktivieren, kommentiere den `ip-watcher`-Service in der `docker-compose.yml` aus:
```yaml
# ip-watcher:
# ...
```
## Sicherheitshinweis
Der IP-Watcher benötigt Zugriff auf den Docker-Socket (`/var/run/docker.sock`), um den `tmserver`-Container neu starten zu können. Dieser Zugriff ermöglicht volle Kontrolle über alle Docker-Container und -Images auf dem Host. Stelle sicher, dass der Host ausreichend abgesichert ist und der Zugriff auf den Docker-Socket auf vertrauenswürdige Dienste beschränkt bleibt.
+8
View File
@@ -188,6 +188,14 @@ XAseco ist ein Server-Controller für Rekorde, Karma, Jukebox und mehr. Siehe [X
> **Hinweis:** Die Server-Zugangsdaten (`SERVER_SA_PASSWORD`, `SERVER_XMLRPC_PORT`) und Dedimania-Daten (`SERVER_LOGIN`, `SERVER_LOGIN_PASSWORD`) werden automatisch aus der bestehenden Konfiguration übernommen.
## IP-Watcher
| Variable | Beschreibung | Standard |
|----------|-------------|----------|
| `IP_WATCHER_INTERVAL` | Prüfintervall in Sekunden, in dem die öffentliche IP geprüft wird | `300` |
> **Hinweis:** Der IP-Watcher verwendet den Docker-Socket (`/var/run/docker.sock`), um `tmserver` bei einer IP-Änderung automatisch neu zu starten. Weitere Details unter [IP-Watcher](ip-watcher.md).
## Debugging
| Variable | Beschreibung | Standard |