Reverse Proxy auf dem Raspberry Pi mit Nginx

© khwi, 123RF

Fernzugriff

Mit dem Duo RasPi und Nginx setzen Sie mit wenig Aufwand eine kostengünstige Lösung für den Fernzugriff auf Geräte im lokalen Netzwerk um.

Internet-Router, NAS, DVB-Receiver, Smart-Home-Zentrale, ja sogar die Heizungsanlage: Immer mehr Endgeräte und Dienste verrichten in den eigenen vier Wänden ihre Arbeit, auf die man auch aus der Ferne zugreifen möchte. Die Voraussetzung dafür: Der Router muss via Internet erreichbar sein und die Netzwerkgeräte innerhalb des lokalen Netzwerks benötigen eine feste IP-Adresse. Über Portfreigaben leitet der Router dann die Anfragen an die jeweiligen Endgeräte weiter. Die Erreichbarkeit des Routers trotz wechselnder IP-Adresse des Internetanschlusses gewährleisten DynDNS-Anbieter wie DynDNS Service (DDNSS [1]). Die Einzelheiten einer solchen Konfiguration hat bereits ein Artikel in RPG 05/2015 beschrieben [2].

Dabei benötigen Sie allerdings für jedes Endgerät eine Portfreigabe. Allein mit den Ports 80 (HTTP) und 443 (HTTPS), die sich in der Regel aus jedem Netz erreichen lassen, kommen Sie hier nicht mehr aus. Zudem stellt der Zugriff via HTTP aufgrund der unverschlüsselt erfolgenden Datenübertragung ein potenzielles Sicherheitsrisiko dar: Ein Angreifer könnte vertrauliche Informationen wie Benutzername und Passwort auslesen. Obendrein unterstützen nicht alle Geräte auch HTTPS. Eine VPN-Verbindung würde diese Probleme lösen, setzt jedoch clientseitig eine bestimmte Konfiguration oder das Einrichten eines VPN-Clients voraus. Zusätzlich müssten Sie vor jedem Zugriff auf das Heimnetz die VPN-Verbindung manuell herstellen und danach wieder beenden.

Die in diesem Artikel vorgestellte Lösung umgeht diese Probleme mithilfe eines Reverse Proxys, der die Client-Anfragen entgegennimmt und an die jeweiligen Endgeräte und Dienste im privaten Netzwerk weiterleitet (Abbildung 1). Dafür muss der DynDNS-Anbieter Wildcards unterstützen, sodass Sie den eigenen Router nicht nur über den registrierten Hostnamen erreichen, zum Beispiel mynetwork.ddnss.de, sondern auch über beliebige Subdomains wie ftp.mynetwork.ddnss.de oder nas.mynetwork.ddnss.de. DDNSS leistet das erfreulicherweise kostenlos.

Abbildung 1: Der Reverse Proxy nimmt Client-Anfragen entgegen und leitet sie an die jeweiligen Endgeräte und Dienste im lokalen Netz weiter.

SSL-Verschlüsselung und das Authentifizieren mit Benutzername und Passwort gewährleisten dabei die Sicherheit der Datenübertragung und des Zugriffs auf den Reverse Proxy. Die folgenden Beispiele gehen davon aus, dass sich der Raspberry Pi in Ihrem Netz nicht nur via IP-Adresse erreichen lässt, sondern auch über einen Hostnamen. Das gelingt am einfachsten durch einen entsprechenden Eintrag in der Hosts-Datei [3] auf dem entfernten Client. Unter Linux editieren Sie dazu die /etc/hosts, unter Windows C:\system32\drivers\etc\hosts.

Nginx einrichten

Der modular aufgebaute Webserver Nginx ("Engine X" [4]) zählt zu den weltweit beliebtesten Vertretern seiner Gattung. Er lässt sich auch als Reverse Proxy, Load Balancer, HTTP-Cache oder Mailserver konfigurieren und steht als quelloffene Software unter der BSD-Lizenz. Nginx zeichnet sich durch einen geringen Ressourcenverbrauch aus, sodass er auch auf dem Raspberry Pi eine sehr gute Performance erreicht.

Zwar findet sich der schlanke Webserver auch in den Raspbian-Repositories, allerdings lediglich in der veralteten Version 1.2.1. Besser kompilieren Sie die aktuellste Nginx-Version direkt aus den Quellen. Dazu richten Sie zunächst über das Raspbian-Paketmanagement alle benötigten Abhängigkeiten ein (Listing 1, Zeile 1 und 2). Anschließend laden Sie den Nginx-Quelltext von der Projektseite herunter, entpacken ihn und wechseln in das dabei neu entstandene Verzeichnis (Zeile 3 bis 5). Von dort aus starten Sie nun das Übersetzen und Einrichten des Servers (Zeile 6 bis 8). Nginx und die zugehörigen Dateien landen unter /usr/local/nginx/. Zu guter Letzt richten Sie noch eine Verknüpfung ein, um Nginx ohne Pfadangabe bedienen zu können (Zeile 9).

Listing 1

 

$ sudo apt-get update
$ sudo apt-get -y install build-essential libpcre3 libpcre3-dev openssl libssl-dev zlib1g zlib1g-dev
$ wget http://nginx.org/download/nginx-1.8.0.tar.gz
$ tar -xzf nginx-1.8.0.tar.gz
$ cd nginx-1.8.0
$ ./configure --with-http_ssl_module
$ make
$ sudo make install
$ sudo ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/nginx

Sie starten den Webserver nun mit dem Befehl sudo nginx und halten ihn bei Bedarf mit sudo nginx -s stop wieder an. Läuft Nginx, zeigt der Befehl ps -fC nginx die zugehörigen Prozesse an (Listing 2). Ein Master-Prozess lädt die Konfiguration und verwaltet einen oder mehrere Worker-Prozesse, die die eigentlichen Anfragen verarbeiten. Die genaue Anzahl der Worker-Prozesse legen Sie in der Nginx-Konfigurationsdatei fest. Für einen ersten Funktionstest nutzen Sie den Befehl curl 127.0.0.1, der den Quellcode der Nginx-Willkommensseite zurückliefert.

Listing 2

 

$ sudo nginx
$ ps -fC nginx
UID       PID   PPID  CMD
root      2292     1  nginx: master process /usr/local/sbin/nginx
nobody    2297  2292  nginx: worker process
$ sudo nginx -s stop

Um Nginx nicht nach jedem Reboot manuell neu aufrufen zu müssen, richten Sie noch ein entsprechendes Skript ein (Listing 3), das Nginx automatisch bei jedem Systemstart mit hochfährt. Sie können den Server darüber hinaus nun mit dem Service-Befehl steuern, also ihn beispielsweise mit sudo service nginx stop anhalten und mit sudo service nginx start wieder aktivieren.

Listing 3

 

$ git clone https://github.com/Fleshgrinder/nginx-sysvinit-script.git
$ cd nginx-sysvinit-script
$ sudo make

Konfiguration

Nginx besteht aus verschiedenen Modulen. Die Konfigurationsdatei enthält Anweisungen, in der Nginx-Terminologie "Direktiven" genannt, die diese Module steuern. Eine Direktive besteht aus dem Namen und einem oder mehreren durch Leerzeichen getrennten Parametern; ein Semikolon schließt die Direktive ab. Ein sogenannter Kontext fasst eine oder mehrere Direktiven in geschweiften Klammern zu einem Block zusammen. Die Minimalkonfiguration aus Listing 4 definiert einen HTTP-Server an Port 80, der statische Webseiten aus /usr/local/nginx/html/ an den Client überträgt.

Listing 4

 

# nginx-01.conf
worker_processes 1;
events {
  worker_connections 1024;
}
http {
  server {
    listen 80 default_server;
    location / {
      root html;
      index index.html index.htm;
    }
  }
}

Innerhalb eines Kontexts dürfen nur ganz bestimmte Anweisungen und weitere Kontexte auftauchen. Details hierzu finden Sie in der Nginx-Dokumentation [5]. So darf die Anweisung worker_connections nur im Kontext events und der Kontext server nur im übergeordneten Kontext http vorkommen. Da jeder Kontext weitere Kontexte enthalten darf, entsteht letztendlich eine hierarchische Struktur, die das Vererben von Anweisungen erlaubt.

Eine im Kontext http definierte Direktive, wie etwa root, gilt beispielsweise auch in den Kontexten server oder location, falls diese sie nicht explizit überschreiben. Anweisungen und Kontexte auf der obersten Ebene der Konfigurationsdatei, wie etwa worker_processes oder http, rechnet man dem impliziten Kontext main zu.

TIPP

Um Konfigurationen zu testen, starten Sie Nginx mit dem Parameter -c, gefolgt vom Dateinamen der fraglichen Konfiguration.

Diesen Artikel als PDF kaufen

Express-Kauf als PDF

Umfang: 6 Heftseiten

Preis € 0,99
(inkl. 19% MwSt.)

Raspberry Pi Geek kaufen

Einzelne Ausgabe
 
Abonnements
 
TABLET & SMARTPHONE APPS
Bald erhältlich
Get it on Google Play

Deutschland

Ähnliche Artikel

Aktuelle Ausgabe

10/2017
Addon-Boards

Diese Ausgabe als PDF kaufen

Preis € 7,99
(inkl. 19% MwSt.)

Neuigkeiten

  • Neues auf der Heft-DVD

    Nur mit dem optimalen System und der richtigen Software nutzen Sie das volle Potenzial eines Mini-PC. Mit der Heft-DVD erhalten Sie nicht nur die neusten Distributionen für den Raspberry Pi und Konsorten, sondern gleichzeitig auch die passenden Programme zu den Artikeln.

  • Aufgewacht!

    Der Raspberry Pi fährt auf Kommando herunter, doch zum Aufwachen fehlt ihm eine Echtzeituhr. Mit einer RTC und ein paar Schaltungen steuern Sie den Schlaf- und Wachrhythmus des Mini-Rechners.

  • Schneller Wechsel

    Mit dem Messkopf ExpEYES Junior erfassen Sie auf einfache Weise die Flimmerfrequenz von verschiedenen Lichtquellen.

  • Knirps

    Der 3,2 Zoll kleine Monitor von Joy-it, zusammen mit dem RasPi kaum größer als eine Packung Zündhölzer, bietet eine interessante Alternative zu einer reinen Headless-Konfiguration. Er erleichtert das Überwachen des Boot-Vorgangs und das Verfolgen von Ausgaben, die nur ein Paar Zeichen oder Zeilen umfassen.

  • Minimalistisch

    Die Raspberry-Pi-Familie bekommt regelmäßig Zuwachs, doch einige Familienmitglieder fristen ein Schattendasein, wie das Compute Module. Das kompakte Board eignet sich bestens für Embedded-Lösungen.

  • Meisencam

    Mit einem RasPi, einer NoIR-Pi-Cam und etwas Elektronik bauen Sie für unter 100 Euro ein digitales Auge, mit dem Sie behutsam Singvögel in der Natur beim Brüten beobachten.

  • Mit einfachen Mitteln

    YunoHost bietet eine große Anzahl von Diensten auf einer bewährten Debian-Server-Plattform, die Sie selbst hosten können.

  • An einem Tisch

    Gemeinsames Arbeiten auf einer mobilen Plattform im lokalen Netzwerk – dazu brauchen Sie nicht mehr als einen SBC und die Software Etherpad Lite.

  • Netz aufspannen

    Ein WLAN-Access-Point bietet einen zusätzlichen Einstieg ins LAN und erlaubt im Zusammenhang mit dem RasPi vielfältige Einsatzszenarien.

  • Diätkost

    Für ältere Modelle des RasPi erweist sich Raspbian mittlerweile als zu schwergewichtig. Mit dem schlanken DietPi helfen Sie diesen Modellen wieder auf die Sprünge.