Docker Toolkit
The adsb.lol docker feed client is a toolkit that allows you to install, run and maintain a ADS-B / UAT / MLAT / ACARS / VDL2 feed client to a multitude of aggregators.
By default, it feeds MLAT+ADSB to adsb.lol. You can enable UAT/ACARS/VDL2, and feed to your plane data to FlightRadar24, Radarbox, Piaware, and more
It is designed to be run on a Raspberry Pi, but can be run on any Linux Debian-like system.
With a few commands , you can easily feed to other community aggregators.
Quick Start with Docker
To get started with the docker client,
Run this as root on a fresh install of Raspberry Pi OS Lite or similar.
This script gets all the requirements for your system.
For your own security, Please consider analysing
the adsblol-init
script which you are about to run on your system.
curl -Ls https://raw.githubusercontent.com/adsblol/feed/main/bin/adsblol-init | bash
cd /opt/adsblol/
cp .env.example .env
Then, set the environment variables.
You can either edit the .env
file, or run adsblol-env set <key> <value>
# Altitude in meters
adsblol-env set FEEDER_ALT_M 542
# Latitude
adsblol-env set FEEDER_LAT 98.76543
# Longitude
adsblol-env set FEEDER_LONG 12.34567
# Timezone (see https://en.wikipedia.org/wiki/List_of_tz_database_time_zones)
adsblol-env set FEEDER_TZ America/New_York
# SDR Serial Number
adsblol-env set ADSB_DONGLE_SERIAL 1090
# Site name (shows up on the MLAT map!)
adsblol-env set MLAT_SITE_NAME "My epic site"
# Would you like to appear on mlat.adsb.lol? Then set this:
adsblol-env unset ADSBLOL_MLAT_CONFIG
These are the minimum environment variables you need to set.
Then, run:
adsblol-debug && adsblol-up
Let’s check if everything is working:
- http://IP:8080 (readsb)
- http://IP:8082 (adsblol)
- https://adsb.lol (ADSB)
- https://mlat.adsb.lol (MLAT)
Usage
By default, the client will feed to adsb.lol.
To see the current list of supported aggregators, see the services.txt file.
The adsblol
service supports feeding to multiple aggregators.
If you have an issue with the feed client, please paste.ee your error logs join our chat on zulip
Restart the stack
adsblol-up
Enabling a service
To enable a service, run adsblol-service enable <service>
To disable a service, run adsblol-service disable <service>
This is a helper command that will edit the services.txt
file, and run adsblol-gen
to generate a new cmdline.txt
.
You may have to define further environment variables in the .env
file.
Then, run adsblol-gen
to generate a new cmdline.txt.
The cmdline.txt is used by the adsblol binaries to know what services to start.
Once you have done this, run adsblol-up
to start the containers.
Troubleshooting
To update, run adsblol-update
Running adsblol-debug
will tell you about common mistakes.
I cannot find myself on the MLAT Map
adsb.lol enables the --privacy
flag for your MLAT client by default.
This hides you from the MLAT map.
Do you want to appear on the map? Then run:
adsblol-env unset ADSBLOL_MLAT_CONFIG && adsblol-up
Logs
adsblol-logs
- view logsadsblol-logs -f
- view logs and follow
Services
adsblol-service enable <service>
- enable a serviceadsblol-service disable <service>
- disable a serviceadsblol-service list
- list all enabled services
Environment
adsblol-env list
- list all environment variablesadsblol-env set <key>
- set an environment variable (also updates if it already exists)adsblol-env unset <key>
- unset an environment variable
SDR
adsblol-sdr test
- Runs rtl_testadsblol-sdr dockertest
- Runs rtl_test in a docker containeradsblol-sdr dockerppm
- Runs rtl_test in a docker container with the intent to estimate the PPM
Reset
adsblol-reset
- reset the /opt/adsblol directory
Thank you SDR-Enthusiasts!
This would not be possible without SDR-Enthusiasts who have made the original docker-compose file.
The client is largely based off of their work plus some command line interface tools to make running the stack a bit simpler.
Their documentation can be very useful in enabling extra feeders. .
Feeding directly to other aggregators
Where possible, adsb.lol commits to share data and ingest data directly with other aggregators which are willing to license their data openly.
The adsblol
service can feed to other aggregators.
In this example, we feed theairtraffic.com and adsbexchange.com two aggregators you might want to consider sharing your data with.
WARNING: ADSBexchange has recently been acquired by a private equity company with unknown plans for the data submitted. It does however have the largest MLAT network, giving you the best chance to locally identify overhead aircraft that do not explicitly share their location data.
TheAirTraffic.com is run by Jack Sweeney
This is not an endorsement and adsb.lol/myself are not affiliated with these aggregators.
Run
NOTE: This is using --privacy
, which excludes you from adsb.lol map, and should exclude you from other aggregators maps too.
adsblol-env set ADSBLOL_ADDITIONAL_NET_CONNECTOR "feed.adsbexchange.com,30004,beast_reduce_out;feed.theairtraffic.com,30004,beast_reduce_out"
adsblol-env set ADSBLOL_ADDITIONAL_MLAT_CONFIG "feed.adsbexchange.com,31090,39001,--privacy;feed.theairtraffic.com,31090,39002,--privacy"
adsblol-env set MLATHUB_NET_CONNECTOR "adsblol,39000,beast_in;adsblol,39001,beast_in;adsblol,39002,beast_in"
If you would like to disable privacy mode, instead, use:
adsblol-env set ADSBLOL_ADDITIONAL_NET_CONNECTOR "feed.adsbexchange.com,30004,beast_reduce_out;feed.theairtraffic.com,30004,beast_reduce_out"
adsblol-env set ADSBLOL_ADDITIONAL_MLAT_CONFIG "feed.adsbexchange.com,31090,39001;feed.theairtraffic.com,31090,39002"
adsblol-env set MLATHUB_NET_CONNECTOR "adsblol,39000,beast_in;adsblol,39001,beast_in;adsblol,39002,beast_in"