Provided by: ttyplot_1.7.0-1_amd64
NAME
ttyplot — realtime terminal plotting utility
SYNOPSIS
ttyplot [options] ttyplot -v ttyplot -h
DESCRIPTION
ttyplot takes data from standard input, most commonly some tool like ping(1), snmpget(1), netstat(8), ifconfig(8), sar(1), vmstat(8), etc., and plots in text mode on a terminal in real time. Supports rate calculation for counters and up to two graphs on a single display using reverse video for second line. The following options are supported: -2 Read two values and draw two plots, the second in reverse video. -r Calculate counter rate and divide by measured sample interval. -c plotchar Use plotchar for the plot line, e.g. ‘@ # % .’ etc. -e errcharmax Use errcharmax for plot error line when value exceeds hardmax. Default: ‘e’. -E errcharmin Use errcharmin for plot error symbol, displayed when plot value is less than hardmin. Default: ‘v’. -s softmax Use softmax as the initial maximum value but allow it to grow with input. -m hardmax Use hardmax as a hard value limit after which an error line will be drawn (see -e). Should be greater than hardmin, if set. -M hardmin Use hardmin as a definite minimum limit of the plot range. If a plot value is less than this, error symbol will be drawn (see -E). -t title Use title as the plot title. -u unit Label the vertical axis unit. -v Print the current version and exit. -h Print this help message and exit.
KEY BINDINGS
When reading data from a pipe, ttyplot accepts the following commands typed at the terminal: q Quit. r Toggle "rate mode" on and off.
EXAMPLES
CPU usage from vmstat(8) using awk(1) to pick the right column: vmstat -n 1 \ | gawk '{ print 100-int($(NF-2)); fflush(); }' \ | ttyplot CPU usage from sar(1) with title and fixed scale to 100%: sar 1 \ | gawk '{ print 100-int($NF); fflush(); }' \ | ttyplot -s 100 -t "cpu usage" -u "%" Memory usage from sar(1), using perl(1), to pick the right column: sar -r 1 \ | perl -lane 'BEGIN{$|=1} print "@F[5]"' \ | ttyplot -s 100 -t "memory used %" -u "%" Number of processes in running and io blocked state: vmstat -n 1 \ | perl -lane 'BEGIN{$|=1} print "@F[0,1]"' \ | ttyplot -2 -t "procs in R and D state" Load average via uptime(1) and awk(1): { while true; do uptime | gawk '{ gsub(/,/, ""); print $(NF-2) }' sleep 1 done } | ttyplot -t "load average" -s load Ping plot with sed(1): ping 8.8.8.8 \ | sed -u 's/^.*time=//g; s/ ms//g' \ | ttyplot -t "ping to 8.8.8.8" -u ms WiFi signal level in -dBM (higher is worse) using iwconfig(8): { while true; do iwconfig 2>/dev/null \ | grep "Signal level" \ | sed -u 's/^.*Signal level=-//g; s/dBm//g' sleep 1 done } | ttyplot -t "wifi signal" -u "-dBm" -s 90 CPU temperature from proc; { while true; do awk '{ printf("%.1f0, $1/1000) }' \ /sys/class/thermal/thermal_zone0/temp sleep 1 done } | ttyplot -t "cpu temp" -u C Fan speed from sensors(1) using grep(1), tr(1) and cut(1): { while true; do sensors | grep fan1: | tr -s " " | cut -d" " -f2 sleep 1 done } | ttyplot -t "fan speed" -u RPM Bitcoin price chart using curl(1) and jq(1): { while true; do curl -sL https://api.coindesk.com/v1/bpi/currentprice.json \ | jq .bpi.USD.rate_float sleep 600 done } | ttyplot -t "bitcoin price" -u usd Stock quote chart: { while true; do curl -sL https://api.iextrading.com/1.0/stock/googl/price echo sleep 600 done } | ttyplot -t "google stock price" -u usd Prometheus load average via node_exporter: { while true; do curl -s http://10.4.7.180:9100/metrics \ | grep "^node_load1 " \ | cut -d" " -f2; sleep 1 done } | ttyplot Network/disk throughput examples ttyplot supports two-line plots for in/out or read/write. Local network throughput for all interfaces combined from sar(1): sar -n DEV 1 | gawk '{ if($6 ~ /rxkB/) { print iin/1000; print out/1000; iin=0; out=0; fflush(); } iin=iin+$6; out=out+$7; }' | ttyplot -2 -u "MB/s" SNMP network throughput for an interface using ‘ttg’: ttg -i 10 -u Mb 10.23.73.254 public 9 \ | gawk '{ print $5,$8; fflush(); }' \ | ttyplot -2 -u Mb/s SNMP network throughput for an interface using snmpdelta(1): snmpdelta -v 2c -c public -Cp 10 \ 10.23.73.254 1.3.6.1.2.1.2.2.1.{10,16}.9 \ | gawk '{ print $NF/1000/1000/10; fflush(); }' \ | ttyplot -2 -t "interface 9 throughput" -u Mb/s Disk throughput from iostat(1): iostat -xmy 1 nvme0n1 \ | stdbuf -o0 tr -s " " \ | stdbuf -o0 cut -d " " -f 4,5 \ | ttyplot -2 -t "nvme0n1 throughput" -u MB/s Rate calculator for counters ttyplot also supports counter style metrics, calculating a rate by measuring time difference between samples. SNMP network throughput for an interface using snmpget(1): { while true; do snmpget -v 2c -c public \ 10.23.73.254 1.3.6.1.2.1.2.2.1.{10,16}.9 \ | awk '{ print $NF/1000/1000; }' sleep 10 done } | ttyplot -2 -r -u "MB/s" Local interface throughput using ip(8) and jq(1): { while true; do ip -s -j link show enp0s31f6 \ | jq '.[].stats64.rx.bytes/1024/1024, \ .[].stats64.tx.bytes/1024/1024' sleep 1 done } | ttyplot -r -2 -u "MB/s" Prometheus node exporter disk throughput for /dev/sda: { while true; do curl -s http://10.11.0.173:9100/metrics \ | awk '/^node_disk_.+_bytes_total{device="sda"}/ { printf("%f0, $2/1024/1024); }' sleep 1 done } | ttyplot -r -2 -u MB/s -t "10.11.0.173 sda writes"
AUTHORS
ttyplot is written by: Antoni Sawicki <tenox@google.com>, Edgar Bonet <linux@edgar-bonet.org> and Sebastian Pipping <sebastian@pipping.org>. Its readme was converted into this manual page by Sijmen J. Mulder <ik@sjmulder.nl>.
BUGS
By default in standard in- and output are is buffered. This can be worked around in various ways: http://www.perkin.org.uk/posts/how-to-fix-stdio-buffering.html. ttyplot quits and erases the screen when there is no more data. This is by design and can be worked around by adding sleep(1) or read(1), for example: { echo 1 2 3; sleep 1000; } | ttyplot When running interactively and non-numeric data is entered (e.g. some key) ttyplot hangs. Press ‘Ctrl^J’ to reset.