SSH-Tunnel: Unterschied zwischen den Versionen
Keine Bearbeitungszusammenfassung |
K (Änderungen von Fkoehler (Diskussion) rückgängig gemacht und letzte Version von Winkler wiederhergestellt) |
||
(7 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt) | |||
Zeile 44: | Zeile 44: | ||
############################################################ | ############################################################ | ||
# create a tunnel from port SERVER_PORT on SERVER_IP, | # create a tunnel from port SERVER_PORT on SERVER_IP, | ||
# to port LOCAL_PORT on localhost | # to port LOCAL_PORT on localhost | ||
Zeile 51: | Zeile 50: | ||
# adjust these variables when installing this script | # adjust these variables when installing this script | ||
TUNNEL_USERNAME= | TUNNEL_USERNAME=$USER | ||
TUNNEL_IP=134.245.135.20 | TUNNEL_IP=134.245.135.20 | ||
SERVER_IP=134.245.135.211 | SERVER_IP=134.245.135.211 | ||
Zeile 68: | Zeile 67: | ||
if [ ! -z "$SYSTEMDRIVE" ]; then | if [ ! -z "$SYSTEMDRIVE" ]; then | ||
# unter Windows | # unter Windows | ||
PROGRAMS=`cygpath "$PROGRAMFILES"` | |||
cd "$PROGRAMS/Mozilla Firefox" | cd "$PROGRAMS/Mozilla Firefox" | ||
nohup firefox.exe localhost:"$LOCAL_PORT" > /dev/null 2>&1 & | nohup firefox.exe localhost:"$LOCAL_PORT" > /dev/null 2>&1 & | ||
else | else | ||
# unter Linux | # unter Linux | ||
firefox localhost:"$LOCAL_PORT" > /dev/null 2>&1 & | nohup firefox localhost:"$LOCAL_PORT" > /dev/null 2>&1 & | ||
fi | fi | ||
</source> | </source> |
Aktuelle Version vom 13. Januar 2010, 15:06 Uhr
Sinn & Zweck des SSH-Tunnels
Ein SSH-Tunnel ermöglicht es, eine verschlüsselte SSH-Verbindung zu einem Dienst eines beliebigen entfernten Computers (Server) über einen zweiten Rechner (Gateway) herzustellen. So können beispielsweise Firewalls oder sonstige Sicherheitsmechanismen auf sichere Weise gezielt umgangen werden.
Das Prinzip
Der User nutzt an seinem Arbeitsrechner A einen SSH-Client (hier der Einfachheit halber den in cygwin implementierten), um eine mit SSH verschlüsselte Verbindung zu dem Gateway-Rechner B herzustellen. Dieser Gateway-Rechner B dient quasi als Sprungbrett und baut wiederum eine (unverschlüsselte) Verbindung zum eigentlichen Server C und dem entsprechenden Dienst auf.
Das Prinzip wird auch als Portforwarding bezeichnet, da der Dienst, der ursprünglich auf dem Server C angeboten wird, über den Sprungbrettrechner B lokal auf den Arbeitsplatzrechner A durchgereicht und dort zur Verfügung gestellt wird.
Der Datenverkehr nimmt nun stets den "Umweg" über den Rechner B:
Anfrage: A --- verschlüsselt --> B --- unverschlüsselt --> C Antwort: A <-- verschlüsselt --- B <-- unverschlüsselt --- C
Was brauche ich?
Folgendes sind die Voraussetzung für die erfolgreiche Umsetzung dieser Idee:
- cygwin-Installation (siehe Cygwin: Basisinstallation) inkl. ssh-client - alternativ bieten auch andere SSH-Clients diese Funktion an.
- Sprungbrettrechner, der vorzugsweise von überall erreichbar ist, mit SSH-Zugang inkl. passender Login-Daten (z.B. acid-Rechner)
Vorgehensweise
Da Hergipedia beispielsweise außerhalb des Universitätsnetzes nicht erreichbar ist, können wir uns eines SSH-Tunnels bedienen: Dafür stellt man im cygwin-Terminal mit folgendem Befehl eine SSH-Verbindung beispielsweise zur acid1 als Sprungbrettrechner her, der dann zum Hergipedia-Webserver auf die IP 134.245.160.160 und den Port 80 weiterverbindet.
Achtung: Für user ist der entsprechende Benutzername einzutragen!
ssh user@acid1 -L 8080:134.245.135.211:80
Für den Fall, dass kein SSH-Keyexchange vorgenommen wurde, wird jetzt nach dem dazugehörigen Passwort gefragt. Sobald die Benutzerautorisierung erfolgreich war, steht der Tunnel. 8080 ist der lokale (TCP-)Port, unter dem nun der Dienst zur Verfügung steht. Der SSH-Client kann nun minimiert werden, muss jedoch im Hintergrund weiterlaufen. Hergipedia kann nun - solange die SSH-Verbindung besteht - unter folgender Adresse abgerufen werden:
http://localhost:8080/mediawiki/
Viel Spaß bei der Nutzung von Hergipedia über den sicheren SSH-Tunnel!
Beispielscript zur Automatisierung
Um z.B. einen Tunnel zur Hergipedia zu erstellen kann nach key-Tausch folgendes Script verwendet werden (Cygwin und Linux):
#!/bin/bash
############################################################
# create a tunnel from port SERVER_PORT on SERVER_IP,
# to port LOCAL_PORT on localhost
# via TUNNEL_USER@TUNNEL_IP
############################################################
# adjust these variables when installing this script
TUNNEL_USERNAME=$USER
TUNNEL_IP=134.245.135.20
SERVER_IP=134.245.135.211
LOCAL_PORT=8081
SERVER_PORT=80
cd /proc
SEARCH_FOR='\000'"$LOCAL_PORT:$SERVER_IP:$SERVER_PORT"
pids=`grep -P "$SEARCH_FOR" [0123456789]*/cmdline | grep -o '[0123456789]\+' | tr '\n' ' '`
test ! -z "$pids" && kill -KILL $pids
nohup ssh "$TUNNEL_USERNAME"@"$TUNNEL_IP" -o TCPKeepAlive=yes -N -f -L "$LOCAL_PORT":"$SERVER_IP":"$SERVER_PORT" > /dev/null 2>&1 &
# check Operating System
if [ ! -z "$SYSTEMDRIVE" ]; then
# unter Windows
PROGRAMS=`cygpath "$PROGRAMFILES"`
cd "$PROGRAMS/Mozilla Firefox"
nohup firefox.exe localhost:"$LOCAL_PORT" > /dev/null 2>&1 &
else
# unter Linux
nohup firefox localhost:"$LOCAL_PORT" > /dev/null 2>&1 &
fi