Ich hatte bei meinem aufgebauten Virtual Radar Server (VRS) bis jetzt nur mäßigen Empfang, da ich bei mir zu Hause die Antenne nicht aufs Dach platzieren konnte. Deswegen habe ich einen zweiten DVB-T Stick gekauft, ihn an einen Raspberry Pi (Raspbian Linux) gehängt, an einem Ort südlich des Frankfurter Flughafens aufs Dach gebaut und schließlich den Feed zu meinem vorhandenen Server hinzugefügt. Dadurch konnte ich die Abdeckung im Raum Frankfurt deutlich verbessern.
Im Folgenden beschreibe ich die Inbetriebnahme eines DVB-T Sticks am Raspberry Pi zum Empfang von ADS-B Flugzeugsignalen, sowie die Einbindung dieses Empfängers an einen zentralen Virtual Radar Server.
Ich verwende den Raspberry Pi also nicht als meinen Virtual Radar Server (VRS, zu dem man sich per Web-Browser (http/s) verbindet um die Flugzeuge zu sehen), sondern empfange lediglich die ADS-B Daten vom DVB-T Stick und leite diese an den bereits vorhandenen VRS weiter. Wenn man es netzwerktechnisch genau nimmt, dann öffnet man auf dem Pi lediglich einen Port, zu dem sich der VRS dann hin verbindet. Die Portfreigabe/Port-Forwarding kann man zum Beispiel über den Internet-Router machen. In meinem Fall habe ich zwischen den zwei Standorten aber ein Site-to-Site VPN.
Hier ein paar Fotos des Aufbaus:
RTL2832U am Raspberry Pi
Bezüglich des Anschlusses des DVB-T Sticks an den Pi muss ich hier nicht viel sagen, da es bereits andere Personen sehr gut dokumentiert haben. Ich verweise also lediglich auf diese sehr ausführliche Doku, die auf die Installation eines DVB-T Sticks am Pi gezielt eingeht (Abschnitt: “Preparing the Raspberry Pi”, mehr nicht!). Daher hier nur kurz die Abfolge aller Befehle:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
sudo apt-get update sudo apt-get upgrade sudo apt-get install git git-core cmake libusb-1.0-0-dev build-essential git clone git://git.osmocom.org/rtl-sdr.git cd rtl-sdr mkdir build cd build cmake ../ -DINSTALL_UDEV_RULES=ON make sudo make install #No output should appear with the following command: sudo ldconfig cd ~ sudo cp ./rtl-sdr/rtl-sdr.rules /etc/udev/rules.d/ cd /etc/modprobe.d sudo nano no-rtl.conf #paste the following three lines: blacklist dvb_usb_rtl28xxu blacklist rtl2832 blacklist rtl2830 # sudo shutdown -r now rtl_test #show something like: #Info: This tool will continuously read from the device, and report if #samples get lost. If you observe no further output, everything is fine. #end with: Strg + c cd ~ git clone git://github.com/MalcolmRobb/dump1090.git cd dump1090 make sudo ./dump1090 --interactive #end with: Strg + c |
Im Endeffekt geht es um das Programm dump1090, welches sehr gut funktioniert und viele Optionen direkt mitliefert. Es endet darin, dass man nach der Installation lediglich folgenden Befehl ausführen muss, um bereits alles getan zu haben:
1 |
./dump1090 --net --quiet |
Lediglich einen Fehler hatte ich beim Testen mit den “rtl_xyz” Programmen. Linux hatte angemerkt, dass ich einen anderen Treiber dafür blacklisten müsste. Ein bisschen googeln hat direkt geholfen: Es war ein Problem mit einem anderen bereits eingebundenem Treiber. Diesen habe ich wie folgt geblacklisted: Die blacklist Datei geöffnet: sudo nano /etc/modprobe.d/raspi-blacklist.conf und folgende Zeile hinzugefügt: blacklist dvb_usb_rtl28xxu . Nach einem Reboot konnte ich sofort das Programm “rtl_adsb” oder eben “dump1090” öffnen. (Ich bin mir aber nicht sicher, ob dieses Problem immer so auftritt, oder ob nur ich eine komische Konstellation hatte.)
Hier ein Listing der Ausgabe von ./dump1090 --interactive . Man sieht die vielen empfangenen Flugzeuge sowie deren Position, Geschwindigkeit, Rufzeichen, etc.:
1 2 3 4 5 6 7 8 9 10 11 12 |
Hex Mode Sqwk Flight Alt Spd Hdg Lat Long Sig Msgs Ti\ ------------------------------------------------------------------------------- 40601f S 0315 BAW165 33000 550 100 50.203 8.720 8 228 0 400804 S 3475 4675 157 251 4 16 0 3cebf0 S 2925 5 4 21 3c666b S DLH25N 10000 265 069 5 21 33 aa64ba S 1000 UAL952 34975 596 137 49.995 8.887 18 1291 0 4008b3 S 0510 BAW48G 34975 542 121 49.640 8.714 5 93 12 4ca75e S 0675 RYR369D 37000 513 091 49.806 9.030 5 487 0 738071 S 3454 ELY006 37000 589 138 50.036 8.939 5 291 2 4b16ba S 1000 SWR815 33000 449 182 49.869 8.997 5 262 24 4692ca S 3123 AEE2BR 32000 336 297 50.189 8.619 5 280 5 |
Eine Alternative zu dem von mir benutzten dump1090 Programm ist übrigens “rtl_adsb”, wie es zum Beispiel hier verwendet wird. Ich hatte ebenfalls mit rtl_adsb begonnen aber mit dump1090 deutlich bessere Erfahrungen gemacht. Es stürzte nie ab und hatte den Netzwerk-Server direkt mit eingebaut. Bei rtl_adsb musste man erst noch zu nc pipen, was mir nicht so gefiel.
Daten im LAN verfügbar machen
Wie also bereits beschrieben, muss dump1090 lediglich mit der Option “–net” laufen, um einen Haufen an Services auf verschiedenen Ports bereit zu stellen. Ich mache dies innerhalb einer “screen” Session um mich sauber vom Pi trennen zu können, ohne dass das laufende Programm abbricht. [Update: siehe weiter unten, um das Programm automatisch zu starten.] Folgende Services werden von dump1090 angeboten (Listing von ./dump1090 --help ):
1 2 3 4 5 6 |
--net-http-port HTTP server port (default: 8080) --net-ri-port TCP raw input listen port (default: 30001) --net-ro-port TCP raw output listen port (default: 30002) --net-sbs-port TCP BaseStation output listen port (default: 30003) --net-bi-port TCP Beast input listen port (default: 30004) --net-bo-port TCP Beast output listen port (default: 30005) |
Per netstat sieht man schön, dass eben diese default Ports auf der Pi geöffnet wurden:
1 2 3 4 5 6 7 |
pi@jw-pi02 ~/dump1090 $ sudo netstat -l -p | grep dump1090 tcp 0 0 *:30002 *:* LISTEN 2293/dump1090 tcp 0 0 *:30003 *:* LISTEN 2293/dump1090 tcp 0 0 *:30004 *:* LISTEN 2293/dump1090 tcp 0 0 *:30005 *:* LISTEN 2293/dump1090 tcp 0 0 *:http-alt *:* LISTEN 2293/dump1090 tcp 0 0 *:30001 *:* LISTEN 2293/dump1090 |
Wenn man mit einem Browser im gleichen Netzwerk dann auf folgende URL geht, sieht man bereits den Webserver von dump1090, welcher direkt auf dem Pi läuft:
1 |
http://<address-or-name-of-Raspberry-Pi>:8080 |
Die 30000er Ports kann man schön per Netcat oder PuTTY testen. Dort sieht man dann ordentlich Text vorbei rasseln.
Hier ein paar Beispielzeilen von dem Output von Port 30002 (RAW):
1 2 3 4 5 6 7 8 9 10 11 12 |
*5D4CC26FD38DE2; *5D44D2635DBF97; *20000F9766CE80; *5F3C6664964D5B; *5D3C49C8A3305E; *02E18F976016CA; *8D4CA7419941C886A0042413DDE4; *20000ABD132A08; *903C1FBDC1A4A594766D30C7BCDE; *903C1FBDC2A4000047B5C9237512; *5D3C4AD34E5E5F; *5D44D2635DBF97; |
Und an Port 30003 (BaseStation) sieht es so aus:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
MSG,7,111,11111,89617E,111111,2014/07/04,22:44:06.728,2014/07/04,22:44:06.734,,15875,,,,,,,,,,0 MSG,8,111,11111,400150,111111,2014/07/04,22:44:06.729,2014/07/04,22:44:06.735,,,,,,,,,,,,0 MSG,7,111,11111,89617E,111111,2014/07/04,22:44:06.730,2014/07/04,22:44:06.735,,15875,,,,,,,,,,0 MSG,7,111,11111,3C6664,111111,2014/07/04,22:44:06.732,2014/07/04,22:44:06.735,,14875,,,,,,,,,,0 MSG,6,111,11111,3C544F,111111,2014/07/04,22:44:06.733,2014/07/04,22:44:06.736,,,,,,,,1000,0,0,0,0 MSG,7,111,11111,3C544F,111111,2014/07/04,22:44:06.734,2014/07/04,22:44:06.737,,20800,,,,,,,,,,0 MSG,5,111,11111,40643D,111111,2014/07/04,22:44:06.737,2014/07/04,22:44:06.737,EZY5497 ,37050,,,,,,,0,,0,0 MSG,7,111,11111,3C4AD3,111111,2014/07/04,22:44:06.740,2014/07/04,22:44:06.738,,5200,,,,,,,,,,0 MSG,8,111,11111,40643D,111111,2014/07/04,22:44:06.741,2014/07/04,22:44:06.738,,,,,,,,,,,,0 MSG,5,111,11111,89617E,111111,2014/07/04,22:44:06.746,2014/07/04,22:44:06.739,,15875,,,,,,,0,,0,0 MSG,8,111,11111,40643D,111111,2014/07/04,22:44:06.747,2014/07/04,22:44:06.739,,,,,,,,,,,,0 MSG,5,111,11111,40643D,111111,2014/07/04,22:44:06.747,2014/07/04,22:44:06.740,,37050,,,,,,,0,,0,0 MSG,8,111,11111,484163,111111,2014/07/04,22:44:06.747,2014/07/04,22:44:06.740,,,,,,,,,,,,0 MSG,7,111,11111,3C666B,111111,2014/07/04,22:44:06.750,2014/07/04,22:44:06.741,,26025,,,,,,,,,,0 |
Bei Port 30005 (Beast) kamen irgendwie nur Steuerzeichen rum. Hm, vielleicht muss man damit irgendwie anders umgehen? (Habe mich nicht näher damit beschäftigt…)
Autostart
Wenn man das Programm automatisch mit dem Raspberry Pi starten lassen möchte, muss man dafür ein init.d Startskript erstellen. Bei mir sieht das so aus: Eine neue Datei im init.d Ordner erstellen:
1 |
sudo nano /etc/init.d/dump1090 |
und folgenden Inhalt reinkopieren:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
#! /bin/sh ### BEGIN INIT INFO # Provides: Start dump1090 in --net mode # Required-Start: # Required-Stop: # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 ### END INIT INFO # Author: Johannes Weber (johannes@webernetz.net) # Aktionen case "$1" in start) /home/pi/dump1090/dump1090 --net --quiet & ;; stop) killall dump1090 ;; restart) killall dump1090 /home/pi/dump1090/dump1090 --net --quiet & ;; esac exit 0 |
Dann noch das Skript ausführbar machen:
1 |
sudo chmod 755 /etc/init.d/dump1090 |
und in die Bootsequenze mit aufnehmen:
1 |
sudo update-rc.d dump1090 defaults |
(Die Konsole gibt an dieser Stelle folgende Meldung aus: update-rc.d: using dependency based boot sequencing ).
Das war’s. Nach einem Neustart des Pis startet dump1090 automatisch. Außerdem kann man es mit folgenden Befehlen händisch starten bzw. stoppen:
1 2 |
sudo service dump1090 start sudo service dump1090 stop |
Feed im VRS hinzufügen
Obwohl dump1090 bereits einen eigenen Webserver (Port 8080) mitliefert war es ja mein Primärziel, die empfangenen Daten an den bereits vorhandenen Virtual Radar Server anzubinden. Das geht im VRS ganz einfach in dem man einen weiteren Feed hinzufügt. Über einen “Merged Feed” kann man dann wiederum die beiden einzelnen Feeds zu einer gemeinsamen Quelle zusammenschließen, damit man auf der Webseite auch wirklich alle Flugzeuge von beiden Empfängern sieht. Hier die entsprechenden Screenshots:
Das war es also schon! Ab jetzt stehen auf meinem Virtual Radar Server unter http://planes.webernetz.net/virtualradar/ zwei Feeds zur Verfügung, wobei der Merged Feed standardmäßig alle empfangenen Flugzeuge anzeigt. Oben im Menü kann man unter “Receiver” auch einen einzelnen Empfänger auswählen. Und in der Tabelle ziemlich rechts sieht man auch den Namen des Empfängers, der das jeweilige Flugzeug gerade empfängt.
Bandbreitenvergleiche
Eine Sache viel mir relativ schnell auf: Ich hatte den Feed vom Pi zunächst als “BaseStation” auf Port 30003 im VRS eingebunden. Dies schlug mit satten 16 GB/Woche an Traffic zu Buche. Huiui. Tagsüber wurde der DSL-Upload mit knapp 300 Kbit/s konstant belastet, was bei einem theoretischen Upload von gerade mal 1 Mbit/s immerhin knapp 1/3 bedeutet.
Testweise habe ich dann auf das Datenformat “Beast” (Port 30005) umgestellt. Und siehe da, es waren nur noch 3,2 GB/Woche. Hier die Auswertung meines Monitoring Systems in der Woche der Umstellung. Schön zu sehen, wie der Traffic sank. Und auch interessant zu sehen, wie sehr die Bandbreite von der Anzahl der Flugzeuge abhängt. Nachts ist einfach weniger los: :)
In einem weiteren Test bin ich von “Beast” auf raw output “AVR or Beast Raw Feed” (Port 30002) umgestiegen. Dies brachte aber kein Unterschied. Deswegen bin ich nun bei Beast geblieben.
CPU Auslastung
Auch interessant finde ich die Auslastung des Raspberry Pi beim Laufen von dump1090. Sie liegt bei sehr konstanten 33 % CPU Last, bzw. bei einem Average Load von 0.6. (Übertaktet habe ich den Pi mit der Stufe “medium”.) Interessant vor allem, dass diese Auslastung sehr konstant ist, also nicht wie bei den oben gezeigten Netzwerkgraphen abhängig von “viele oder wenig Flugzeuge” ist:
Schönes Beispiel
Hier noch mal ein Screenshot von meinem Server mit beiden Empfängern. Ich hatte einen Filter “Altitude between 1 and 7000” eingestellt um nur die startenden/landenden Flugzeuge zu sehen. Man sieht sehr schön, wie sich alle Flugzeuge in die drei Landebahnen vom Frankfurter Flughafen einreihen. ;) Die beiden roten Pfeile zeigen die Positionen meiner beiden Empfänger an. Also ziemlich gut ober- und unterhalb des Frankfurter Flughafens positioniert:
Und nun heißt es: Auf ans Nachmachen!
Danke für die Anleitung. Irgendwann in den Sommerferien werde ich mich daran machen.
Eine Sache: Die Seite http://planes.webernetz.net/virtualradar kann ich nicht erreichen, konnte es glaube ich auch noch nie…
Ich habe mir das aufgebaut. Mit dump1090 sehe ich die empfangenen Daten. Starte ich nun den Browser, werden mir die die Uhrzeiten oben rechts angezeigt. Aber weder die Karte mit den Flugzeugen noch die Liste der Daten werden gezeigt. Wie schon geschrieben, es erscheinen nur die zwei Uhren. Kann mir jemand einen Tipp geben was da falschläuft?
Hallo Peter,
hm, rufst du dump1090 mit –net und –interactive auf? Siehst du dann auf der Konsole die Daten und weiterhin nichts auf der Weboberfläche? Komisch. Einfach noch mal probieren und/oder die Kiste neustarten. :)
Hallo,
vielen Dank für die schöne Anleitung.
Die Einrichtung hat soweit funktioniert, allerdings empfange ich keine Daten! Weder über’s Webinterface, noch über die Konsolenausgabe (./dump1090 –interactive).
Meine Antenne steht derzeit aus Kabelgründen innen am Fenster. Könnte es daran liegen, oder wirds eine Konfiguration sein?
Hallo Stefan,
hm, also wenn dir das “./dump1090 –interactive” keinen Fehler ausspuckt, dann könnte es am Empfang der Antenne liegen. Häng sie doch mal testweise aus dem Fenster raus. Und dann vergleiche, ob bei FlightRadar24 gerade ein Flugzeug in der Umgebung ist. ;)
Die ersten Zeilen beim Aufruf von dump1090 sehen bei mir immer wie folgt aus. Ist das bei dir auch so? Also vor allem das “Found 1 device…”
—
pi@jw-pi02~/dump1090 $sudo ./dump1090 –quiet –net
Found 1 device(s):
0: Realtek, RTL2838UHIDIR, SN: 00000001 (currently selected)
Found Rafael Micro R820T tuner
Max available gain is: 49.60
Setting gain to: 49.60
Exact sample rate is: 2000000.052982 Hz
Gain reported by device: 49.60
—