6.0 KiB
navigation, title, main
navigation | title | main | ||
---|---|---|---|---|
true | Speedtest Tracker |
|
:ellipsis{left=0px width=40rem top=10rem blur=140px}
Speedtest Tracker
::alert{type="info"} 🎯 Objectives:
- Install Speedtest Tracker
- Expose Speedtest Tracker with SWAG
::
Speedtest Tracker is a container that allows you to schedule regular speed tests in order to log your server's internet connection status.
Installation
::alert{type="info"} :::list{type="info"}
- We will use the Docker image maintained by LinuxServer.io ::: ::
File structure:
root
└── docker
└── speedtest-tracker
└── data
└── config
In a terminal, generate a key using the following command:
echo -n 'base64:'; openssl rand -base64 32;
Take note of the key.
Open Dockge, click on compose
, name the stack speedtest-tracker
, then paste the following:
---
services:
speedtest-tracker:
image: lscr.io/linuxserver/speedtest-tracker:latest
restart: unless-stopped
container_name: speedtest-tracker
ports:
- ${PORT}$:80
environment:
- PUID=${PUID}
- PGID=${GUID}
- TZ=Europe/Paris
- APP_KEY=${API_KEY}
- DB_CONNECTION=sqlite
- SPEEDTEST_SCHEDULE=${SCHEDULE}
volumes:
- /docker/speedtest-tracker/data/config:/config
Find your PUID
and GUID
by running the following command:
id yourusername
In the .env
file, set the variable API_KEY
with the key you generated and add a cron-style test schedule, as well as your PUID
and GUID
, for example:
SCHEDULE=15 */6 * * * # every 6 hours
KEY=base64:zihejehkj8_nzhY/OjeieR= # your key
PUID=1000
GUID=1000
PORT=3225 # port to access the web UI
::alert{type="success"} ✨ Tip: You can configure additional environment variables by referring to the official documentation. ::
Deploy the container and go to http://yourserverip:3225
. Log in with the account admin@exemple.com
and the password password
. Don’t forget to change your ID and password once logged in!
Expose Speedtest Tracker
::alert{type="info"}
📋 Prerequisites:
We assume that you've already created a subdomain like speedtest.yourdomain.com
in your DNS zone with a CNAME
pointing to yourdomain.com
, and unless you’re using Cloudflare Zero Trust, you've also forwarded port 443
from your router to port 443
of your server in your NAT rules.
::
Now we want to expose Speedtest Tracker to the internet so you can access it remotely. We assume you've set up the DNS CNAME
for speedtest.yourdomain.com
pointing to yourdomain.com
.
::alert{type="warning"} :::list{type="warning"}
- Speedtest Tracker does not use multi-factor authentication. Exposing it on the internet could compromise connected devices. Do so only if you use a multi-factor system like Authentik. Otherwise, avoid using SWAG and prefer a VPN like Wireguard. ::: ::
Open the speedtest.subdomain.conf
file:
sudo vi /docker/swag/config/nginx/proxy-confs/speedtest.subdomain.conf
Configure it like this:
## Version 2023/12/19
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name speedtest.*;
include /config/nginx/ssl.conf;
client_max_body_size 0;
#if ($lan-ip = yes) { set $geo-whitelist yes; }
#if ($geo-whitelist = no) { return 404; }
if ($geo-blacklist = no) { return 404; }
# Authentication options (uncomment as needed)
#include /config/nginx/ldap-server.conf;
#include /config/nginx/authelia-server.conf;
#include /config/nginx/authentik-server.conf;
location / {
# Basic auth
#auth_basic "Restricted";
#auth_basic_user_file /config/nginx/.htpasswd;
# Per-location authentication
#include /config/nginx/ldap-location.conf;
#include /config/nginx/authelia-location.conf;
#include /config/nginx/authentik-location.conf;
include /config/nginx/proxy.conf;
include /config/nginx/resolver.conf;
set $upstream_app speedtest-tracker;
set $upstream_port 3225;
set $upstream_proto http;
proxy_pass $upstream_proto://$upstream_app:$upstream_port;
}
}
Save and exit. The configuration will update in a few seconds.
::alert{type="info"} :::list{type="info"}
- By default, SWAG doesn’t know the name "speedtest-tracker". To allow access, you need to add Speedtest Tracker’s network to SWAG’s
compose.yml
. ::: ::
Go to Dockge, and edit SWAG’s compose to include Speedtest Tracker’s network:
services:
swag:
container_name: # ...
# ...
networks:
# ...
- speedtest-tracker
networks:
# ...
speedtest-tracker:
name: speedtest-tracker_default
external: true
Restart the stack by clicking "Deploy" and wait for SWAG to be fully up.
::alert{type="info"} :::list{type="info"}
- This assumes the Speedtest Tracker network is named
speedtest-tracker_default
. You can verify the connection by visiting SWAG’s dashboard athttp://yourserverip:81
. ::: ::
Wait a moment, then visit https://speedtest.yourdomain.com
in your browser — you should be redirected to Speedtest Tracker. You can check service status via the dashboard (http://yourserverip:81
from the local network).
::alert{type="success"}
✨ You can protect this app with Authentik by opening speedtest.subdomain.conf
and uncommenting
include /config/nginx/authentik-server.conf;
and include /config/nginx/authentik-location.conf;
.
Don’t forget to create an application and provider in Authentik.
::