-
-
Notifications
You must be signed in to change notification settings - Fork 129
Docker
A pre-built Docker image is available at https://github.com/orgs/projecthorus/packages/container/package/radiosonde_auto_rx. To install this, follow the instructions below.
It is highly recommended that you use the latest version of Docker, rather than the one available from your systems default package repositories.
A quick way to install the latest version of Docker is by using the convenience script:
curl -fsSL https://get.docker.com -o get-docker.sh
sudo sh get-docker.sh
To be able to run docker
commands as your non-root user (recommended), run:
sudo usermod -aG docker $(whoami)
You will need to logout and log back in afterwards to pick up the changes to group membership.
The RTL DVB kernel modules must first be blacklisted on the Docker host. RTL-SDR itself is not required on the Docker host. This can be accomplished using the following commands:
echo 'blacklist dvb_usb_rtl28xxu' | sudo tee /etc/modprobe.d/blacklist-dvb_usb_rtl28xxu.conf
sudo modprobe -r dvb_usb_rtl28xxu
If the modprobe -r
command errors, a reboot may be required to unload the module.
station.cfg
should be configured as per Configuration-Settings. An example station.cfg
can be found here.
Also ensure that an empty directory named log
is available if you wish to retain log files.
A quick way to create these files, assuming you want to store them in your home directory, is:
mkdir -p ~/radiosonde_auto_rx/log
curl -o ~/radiosonde_auto_rx/station.cfg https://raw.githubusercontent.com/projecthorus/radiosonde_auto_rx/master/auto_rx/station.cfg.example
Make sure to edit ~/radiosonde_auto_rx/station.cfg
to your requirements. e.g. if operating from a terminal, run nano ~/radiosonde_auto_rx/station.cfg
to edit the file. It running from a GUI version of Raspbian, you can just open this file in a text editor.
docker run \
-d \
--name radiosonde_auto_rx \
--restart="always" \
--device=/dev/bus/usb \
--network=host \
-v ~/radiosonde_auto_rx/station.cfg:/opt/auto_rx/station.cfg:ro \
-v ~/radiosonde_auto_rx/log/:/opt/auto_rx/log/ \
ghcr.io/projecthorus/radiosonde_auto_rx:latest
Note that the above is one single command spread across multiple lines. Copy and paste it into your terminal.
Once this is run, the auto_rx Docker image will automatically start on system boot.
Substitute ~/radiosonde_auto_rx/station.cfg
and ~/radiosonde_auto_rx/log/
in the above command with the relevant local paths on your Docker host if not storing these in your home directory as per the above examples.
--restart="always"
will result in the container automatically restarting after a failure or host system reboot, so you don't need to run this command again unless updating the docker image (see below).
You can check the status of the container by checking the logs:
docker logs --tail 50 --follow radiosonde_auto_rx
Once running, you can access the Web UI through http://<docker-host>:5000
. If accessing a auto_rx instance running on a local machine, that address would be http://localhost:5000
.
docker pull ghcr.io/projecthorus/radiosonde_auto_rx:latest
You must then remove and recreate the container to use the newly pulled version, for example:
docker pull ghcr.io/projecthorus/radiosonde_auto_rx:latest
docker stop radiosonde_auto_rx
docker rm radiosonde_auto_rx
docker run \
-d \
--name radiosonde_auto_rx \
--restart="always" \
--device=/dev/bus/usb \
--network=host \
-v ~/radiosonde_auto_rx/station.cfg:/opt/auto_rx/station.cfg:ro \
-v ~/radiosonde_auto_rx/log/:/opt/auto_rx/log/ \
ghcr.io/projecthorus/radiosonde_auto_rx:latest
You can also switch to the testing branch of auto_rx by replacing latest
with testing
above.
Make sure to check the Configuration File Changelog for changes you may need to make to your station.cfg file.
Restarting the container is useful for picking up changes to station.cfg
.
docker restart radiosonde_auto_rx
docker stop radiosonde_auto_rx
docker rm radiosonde_auto_rx
docker logs radiosonde_auto_rx
docker logs --tail 50 radiosonde_auto_rx
docker logs --tail 50 --follow radiosonde_auto_rx
docker exec -it radiosonde_auto_rx /bin/bash
If you wish to use Docker Compose instead of the docker
CLI, the following basic docker-compose.yml
can be used as a starting point:
services:
radiosonde_auto_rx:
container_name: radiosonde_auto_rx
devices:
- /dev/bus/usb
image: ghcr.io/projecthorus/radiosonde_auto_rx:latest
network: host
restart: always
volumes:
- ~/radiosonde_auto_rx/station.cfg:/opt/auto_rx/station.cfg:ro
- ~/radiosonde_auto_rx/log/:/opt/auto_rx/log
station.cfg
should be configured as per Configuration-Settings. An example station.cfg
can be found here.
Substitute ~/radiosonde_auto_rx/station.cfg
and ~/radiosonde_auto_rx/log/
in the above configuration with the relevant local paths on your Docker host if not storing these in your home directory as per the above examples.
For help getting started with Docker Compose, @mikenye's ADS-B Reception, Decoding & Sharing with Docker guide is a great resource.