release-1.3.1 #17
@@ -117,3 +117,9 @@ XASECO_DB_PASSWORD="4KpL8mWnR3xYvBq"
|
|||||||
# Dedimania-Nation (3-Zeichen IOC-Code, z.B. DEU, AUT, CHE)
|
# Dedimania-Nation (3-Zeichen IOC-Code, z.B. DEU, AUT, CHE)
|
||||||
# Server-Login und -Passwort werden automatisch aus SERVER_LOGIN / SERVER_LOGIN_PASSWORD übernommen.
|
# Server-Login und -Passwort werden automatisch aus SERVER_LOGIN / SERVER_LOGIN_PASSWORD übernommen.
|
||||||
XASECO_DEDIMANIA_NATION=DEU
|
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
|
||||||
|
|||||||
41
.gitea/workflows/docker-publish.yml
Normal file
41
.gitea/workflows/docker-publish.yml
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
name: Build & Push Docker Image
|
||||||
|
|
||||||
|
# Wird ausgeloest, wenn ein Tag wie "v1.3.0" gepusht wird
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- 'v*'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-push:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
# "v1.3.0" -> "1.3.0" (fuehrendes "v" entfernen)
|
||||||
|
- name: Version aus Tag extrahieren
|
||||||
|
id: version
|
||||||
|
run: |
|
||||||
|
VERSION=$(echo "${{ gitea.ref_name }}" | sed 's/^v//')
|
||||||
|
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Bei Gitea Registry einloggen
|
||||||
|
run: |
|
||||||
|
echo "${{ secrets.REGISTRY_TOKEN }}" | \
|
||||||
|
docker login git.techniverse.net \
|
||||||
|
--username "${{ secrets.REGISTRY_USER }}" \
|
||||||
|
--password-stdin
|
||||||
|
|
||||||
|
- name: Docker Image bauen
|
||||||
|
run: |
|
||||||
|
docker build \
|
||||||
|
-t git.techniverse.net/scriptos/trackmania-server:${{ steps.version.outputs.VERSION }} \
|
||||||
|
-t git.techniverse.net/scriptos/trackmania-server:latest \
|
||||||
|
.
|
||||||
|
|
||||||
|
- name: Docker Image pushen
|
||||||
|
run: |
|
||||||
|
docker push git.techniverse.net/scriptos/trackmania-server:${{ steps.version.outputs.VERSION }}
|
||||||
|
docker push git.techniverse.net/scriptos/trackmania-server:latest
|
||||||
31
assets/bin/WatchPublicIP.sh
Normal file
31
assets/bin/WatchPublicIP.sh
Normal 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
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
tmserver:
|
tmserver:
|
||||||
image: git.techniverse.net/scriptos/trackmania-server:1.3.0
|
image: git.techniverse.net/scriptos/trackmania-server:1.3.1
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
container_name: tmserver
|
container_name: tmserver
|
||||||
@@ -53,6 +53,22 @@ services:
|
|||||||
tmserver_net:
|
tmserver_net:
|
||||||
ipv4_address: 172.20.60.11
|
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:
|
networks:
|
||||||
tmserver_net:
|
tmserver_net:
|
||||||
name: tmserver.dockernetwork.local
|
name: tmserver.dockernetwork.local
|
||||||
|
|||||||
@@ -15,6 +15,7 @@
|
|||||||
| [AdminServ](adminserv.md) | Einrichtung der Server-Verwaltungsoberfläche |
|
| [AdminServ](adminserv.md) | Einrichtung der Server-Verwaltungsoberfläche |
|
||||||
| [RemoteCP](remotecp.md) | Alternative Server-Verwaltungsoberfläche (inkl. Mods/Skins) |
|
| [RemoteCP](remotecp.md) | Alternative Server-Verwaltungsoberfläche (inkl. Mods/Skins) |
|
||||||
| [XAseco](xaseco.md) | Server-Controller für Rekorde, Karma und Jukebox |
|
| [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 |
|
| [Ports](ports.md) | Freigegebene Ports und deren Verwendung |
|
||||||
|
|
||||||
## Projektstruktur
|
## Projektstruktur
|
||||||
@@ -26,6 +27,7 @@
|
|||||||
│ │ ├── remoteCP_v4.0.3.5.zip # RemoteCP Web-UI
|
│ │ ├── remoteCP_v4.0.3.5.zip # RemoteCP Web-UI
|
||||||
│ │ ├── RunTrackmaniaServer.sh # Container-Startscript
|
│ │ ├── RunTrackmaniaServer.sh # Container-Startscript
|
||||||
│ │ ├── TrackmaniaServer_2011-02-21.zip # Trackmania Server Binary
|
│ │ ├── TrackmaniaServer_2011-02-21.zip # Trackmania Server Binary
|
||||||
|
│ │ ├── WatchPublicIP.sh # IP-Watcher-Script
|
||||||
│ │ └── xaseco_v1.16.zip # XAseco Server-Controller
|
│ │ └── xaseco_v1.16.zip # XAseco Server-Controller
|
||||||
│ ├── config/
|
│ ├── config/
|
||||||
│ │ ├── adminserv/ # AdminServ-Konfiguration
|
│ │ ├── adminserv/ # AdminServ-Konfiguration
|
||||||
@@ -45,6 +47,9 @@
|
|||||||
│ │ └── teamspeak3.xml # TeamSpeak3-Konfiguration fuer XAseco
|
│ │ └── teamspeak3.xml # TeamSpeak3-Konfiguration fuer XAseco
|
||||||
│ └── db/
|
│ └── db/
|
||||||
│ └── init-xaseco-db.sh # MariaDB Init-Script fuer XAseco-DB
|
│ └── init-xaseco-db.sh # MariaDB Init-Script fuer XAseco-DB
|
||||||
|
├── .gitea/
|
||||||
|
│ └── workflows/
|
||||||
|
│ └── docker-publish.yml # CI/CD: Docker Image Build & Push bei neuem Release-Tag
|
||||||
├── docs/ # Dokumentation
|
├── docs/ # Dokumentation
|
||||||
├── docker-compose.yml # Docker Compose Konfiguration
|
├── docker-compose.yml # Docker Compose Konfiguration
|
||||||
├── Dockerfile # Docker Build-Definition
|
├── Dockerfile # Docker Build-Definition
|
||||||
|
|||||||
36
docs/ip-watcher.md
Normal file
36
docs/ip-watcher.md
Normal 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.
|
||||||
@@ -43,11 +43,9 @@ Die Konfiguration erfolgt über die `.env`-Datei, die automatisch eingelesen wir
|
|||||||
Alternativ kannst du das Image auch selbst bauen:
|
Alternativ kannst du das Image auch selbst bauen:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker build -t tmserver:latest -t tmserver:1.3.0 .
|
docker build -t tmserver:latest .
|
||||||
```
|
```
|
||||||
|
|
||||||
Damit wird das Image mit zwei Tags erstellt: `tmserver:latest` und `tmserver:1.3.0`.
|
|
||||||
|
|
||||||
Anschließend den Server starten:
|
Anschließend den Server starten:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
|
|||||||
@@ -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.
|
> **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
|
## Debugging
|
||||||
|
|
||||||
| Variable | Beschreibung | Standard |
|
| Variable | Beschreibung | Standard |
|
||||||
|
|||||||
Reference in New Issue
Block a user