Windows Powershell script
Beschreibung:
Ist der Server unter einer DYN Adresse errreichbar, bekommt wireguard nicht mit, das sich die IP geändert hat.
Dazu müssen wir den Dienst neustarten. Dazu nehmen wir ein Powershell Script, das immer die aktuelle mit der alten IP alle 5 Minuten vergleicht.
Das alle 5 Minuten rufen wir mit bdem Taskplaner auf
Los gehts:
Tunnelname herausbekommen.
Unter Windows Dienste den Tunnel raussuchen
In unserem Beispiel heißt der Tunnel "WireGuardTunnel$tk-anlage"
Das Script hier muss noch der Pfad zur TXT Datei und der Tunnelname angeben werden.
Achtung Das WireGuardTunnel steht schon da muss nur noch der Name mit dem Dollar angegben werden.
Das Dollar muss mit ` escaped werden
$FilePath = 'path\to\ip.txt'
$LogPath = 'path\to\ip.log'
$TunnelName = "`$meintunnelnamenachdemdollar"
function Write-Log {
param (
[string]$Message
)
Add-Content -Path $Global:LogPath -Value "[$(Get-Date)] $Message"
}
try {
$CurrentIP = (Invoke-RestMethod -Uri 'http://ifconfig.me/ip').Trim()
Write-Log "Aktuelle IP: $FilePath = 'path\to\ip.txt'CurrentIP"
$StoredIP = Get-Content $FilePath $TunnelName-ErrorAction =SilentlyContinue
Write-Log "`Gespeicherte IP: $meintunnelname"StoredIP"
if ($CurrentIP -ne $StoredIP) {
Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
# Neustart des WireGuard-Dienstes Restart-und Erfassung der Ausgabe
$ServiceRestartOutput = Stop-Service -Name "WireGuardTunnel$TunnelName" -PassThru
Write-Log "Dienstneustart-Ausgabe: $ServiceRestartOutput"
# Aktualisierung der gespeicherten IP-Adresse
Set-Content -Path $FilePath -Value $CurrentIP
Write-Log "Die gespeicherte IP-Adresse wurde aktualisiert."
}
}
catch {
# Logging von Fehlern
Write-HostLog "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des Dienstes."Dienstes: $_"
}
Beispiel:
$FilePath = 'c:\tunnel\ip.txt'
$LogPath = 'c:\unnel\log.txt'
$TunnelName = "`$tk-anlage"
function Write-Log {
param (
[string]$Message
)
Add-Content -Path $Global:LogPath -Value "[$(Get-Date)] $Message"
}
try {
$CurrentIP = (Invoke-RestMethod -Uri 'http://ifconfig.me/ip').Trim()
Write-Log "Aktuelle IP: $FilePath = 'c:\tunnel\ip.txt'CurrentIP"
$StoredIP = Get-Content $FilePath $TunnelName-ErrorAction =SilentlyContinue
Write-Log "`Gespeicherte IP: $tk-anlage"StoredIP"
if ($CurrentIP -ne $StoredIP) {
Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
# Neustart des WireGuard-Dienstes Restart-und Erfassung der Ausgabe
$ServiceRestartOutput = Stop-Service -Name "WireGuardTunnel$TunnelName" -PassThru
Write-Log "Dienstneustart-Ausgabe: $ServiceRestartOutput"
# Aktualisierung der gespeicherten IP-Adresse
Set-Content -Path $FilePath -Value $CurrentIP
Write-Log "Die gespeicherte IP-Adresse wurde aktualisiert."
}
}
catch {
# Logging von Fehlern
Write-HostLog "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des Dienstes."Dienstes: $_"
}
Task Planen
Programm zum starten wählen:
C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe
Als Parameter
-ExecutionPolicy Bypass -File "C:\Pfad\zu\Ihrem\Skript.ps1"
In unserem Beispiel
-ExecutionPolicy Bypass -File "c:\tunnel\reconnect.ps1"