123456789101112131415161718192021222324252627282930313233343536373839 |
- #!/usr/bin/env bash
- DEBUG=0
- if [ "$1" == "debug" ]; then
- DEBUG=1
- set -x
- shift
- fi
- # InfluxDB variables
- influxdb_proto=${INFLUXDB_PROTO:-http}
- influxdb_host=${INFLUXDB_HOST:-influxdb}
- influxdb_port=${INFLUXDB_PORT:-8086}
- influxdb_db=${INFLUXDB_DB:-speedtest}
- influxdb_url="${influxdb_proto}://${influxdb_host}:${influxdb_port}"
- # run speedtest & store result
- json_result=$(speedtest -f json --accept-license --accept-gdpr)
- # Extract data from speedtest result
- result_id=$(echo "${json_result}" | jq -r '.result.id')
- ping_latency=$(echo "${json_result}" | jq -r '.ping.latency')
- download_bandwidth=$(echo "${json_result}" | jq -r '.download.bandwidth')
- upload_bandwidth=$(echo "${json_result}" | jq -r '.upload.bandwidth')
- packet_loss=$(echo "${json_result}" | jq -r '.packetLoss')
- # Write metric to InfluxDB
- INFLUXDB_APPEND="speedtest,result_id=${result_id} ping_latency=${ping_latency},download_bandwidth=${download_bandwidth},upload_bandwidth=${upload_bandwidth},packet_loss=${packet_loss}"
- [ ${DEBUG} -eq 1 ] && echo "[DEBUG] INFLUXDB: ${INFLUXDB_APPEND}"
- # Ensure InfluxDB database exists
- curl \
- -d "q=CREATE DATABASE ${influxdb_db}" \
- "${influxdb_url}/query"
- curl \
- -d "${INFLUXDB_APPEND}" \
- "${influxdb_url}/write?db=${influxdb_db}"
|