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:

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 logs
  • adsblol-logs -f - view logs and follow

Services

  • adsblol-service enable <service> - enable a service
  • adsblol-service disable <service> - disable a service
  • adsblol-service list - list all enabled services

Environment

  • adsblol-env list - list all environment variables
  • adsblol-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_test
  • adsblol-sdr dockertest - Runs rtl_test in a docker container
  • adsblol-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"