Skip to content

Instantly share code, notes, and snippets.

@Jamesits
Created August 6, 2016 14:04
Show Gist options
  • Save Jamesits/b0a1879724c2cdf3179c56fd6db5afab to your computer and use it in GitHub Desktop.
Save Jamesits/b0a1879724c2cdf3179c56fd6db5afab to your computer and use it in GitHub Desktop.
Display net speed.
#!/bin/bash
# Public Domain
# (someone claimed the next lines would be useful for…
# people. So here goes: © 2012 Stefan Breunig
# stefan+measure-net-speed@mathphys.fsk.uni-heidelberg.de)
# modified by James Swineson <github@public.swineson.me>
# interfaces
interfaces=(enp1s0 wlp2s0)
# path to store the old results in
path="/dev/shm/measure-net-speed"
# grabbing data for each adapter.
# You can find the paths to your adapters using
# find /sys/devices -name statistics
# If you have more (or less) than two adapters, simply adjust the script here
# and in the next block.
rx=0
tx=0
for i in ${interfaces[@]}; do
read i_rx < "/sys/class/net/${i}/statistics/rx_bytes"
read i_tx < "/sys/class/net/${i}/statistics/tx_bytes"
rx=$(( $rx + $i_rx ))
tx=$(( $tx + $i_tx ))
done
# get time
time=$(date +%s)
# write current data if file does not exist. Do not exit, this will cause
# problems if this file is sourced instead of executed as another process.
if ! [[ -f "${path}" ]]; then
echo "${time} ${rx} ${tx}" > "${path}"
chmod 0666 "${path}"
fi
# read previous state and update data storage
read old < "${path}"
echo "${time} ${rx} ${tx}" > "${path}"
# parse old data and calc time passed
old=(${old//;/ })
time_diff=$(( $time - ${old[0]} ))
# sanity check: has a positive amount of time passed
if [[ "${time_diff}" -gt 0 ]]; then
# calc bytes transferred, and their rate in byte/s
rx_diff=$(( $rx - ${old[1]} ))
tx_diff=$(( $tx - ${old[2]} ))
rx_rate=$(( $rx_diff / $time_diff ))
tx_rate=$(( $tx_diff / $time_diff ))
# shift by 10 bytes to get KiB/s. If the value is larger than
# 1024^2 = 1048576, then display MiB/s instead (simply cut off
# the last two digits of KiB/s). Since the values only give an
# rough estimate anyway, this improper rounding is negligible.
# incoming
rx_kib=$(( $rx_rate >> 10 ))
if [[ "$rx_rate" -gt 1048576 ]]; then
echo -n "${rx_kib:0:-3}.${rx_kib: -3:-2}M↓"
else
echo -n "${rx_kib}K↓"
fi
# outgoing
tx_kib=$(( $tx_rate >> 10 ))
if [[ "$tx_rate" -gt 1048576 ]]; then
echo -n "${tx_kib:0:-3}.${tx_kib: -3:-2}M↑"
else
echo -n "${tx_kib}K↑"
fi
else
echo -n " ? "
fi
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment