Tmux-Packet-Loss is a plugin for Tmux that displays the percentage of packet loss on your connection. It calculates the loss level as a weighted average by default, giving more emphasis to recent checks.
- New option @packet-loss-run_disconnected
- Losses are displayed, but no stats are saved for the first 30 seconds. This avoids getting initial errors before the network is re-established saved into the history during a laptop resume.
- Fixed boolean parameter handling to allow for yes/no or true/false options.
- Renamed variables and defaults to match the Tmux option names.
- Refactored code into more task-isolated modules.
Partial status bar configuration: #{battery_smart} #{packet_loss}%a %h-%d %H:%M
Plugin output takes no space when under @packet-loss-level_disp level.
Display | With hist avg | Status |
---|---|---|
under threshold | ||
low level losses | ||
alert level losses | ||
critical level losses |
If @packet-loss-display_trend
is yes, change since the previous check is indicated
with a prefix character
Display | Status |
---|---|
Increasing | |
Stable | |
Decreasing |
This plugin runs a background process using repeated runs of ping to determine % package loss. The loss level is calculated as a weighted average of the stored data points by default, making the latest checks stand out.
Unless @packet-loss-run_disconnected
is yes
, the background monitor
terminates if no clients are connected. It will resume as soon as any
client re-connects.
The background process monitors the tmux server pid, and terminates if the tmux server exits.
If the monitor fails to calculate loss, packet loss above 100% is reported. So far I have created one special case ping parser, for iSH running Debian 10.
Result | Explanation |
---|---|
101 | Failed to find % loss in ping output. Temporary issue. Some pings don't report loss % if there is no connection to the host. |
102 | loss reported was < 0 or > 100, odd but hopefully temporary |
103 | ping reported error, on some distros this happens if there is no netork connection |
201 | Could not parse the output. This condition is unlikely to self-correct. If you file the output of ping -c 5 8.8.4.4 as an Issue and also mention what Operating System this is and any other factors you think are relevant, I will try to fix it by including parsing of that output format. |
Ensure you have the following dependencies installed:
tmux 1.9
sqlite3
bash
Tmux-Packet-Loss has been tested and verified to work in the following environments:
- Linux
- MacOS
- iSH
- Windows Subsystem for Linux (WSL)
Installation with Tmux Plugin Manager (tpm) (recommended)
Add the plugin to the list of TPM plugins in .tmux.conf
:
set -g @plugin 'jaclu/tmux-packet-loss'
Hit prefix + I
to fetch the plugin and source it. That's it!
Clone the repository:
git clone https://github.com/jaclu/tmux-packet-loss.git ~/clone/path
Add this line to the bottom of .tmux.conf
:
run-shell ~/clone/path/packet-loss.tmux
Reload the Tmux environment with $ tmux source-file ~/.tmux.conf
- that's it!
Code | Action |
---|---|
#{packet_loss} |
Displays packet loss if at or above @packet-loss-level_disp Otherwise nothing |
Variable | Default | Purpose |
---|---|---|
@packet-loss-ping_host | 8.8.8.8 | The host to ping. Choosing a well-connected & replicated host like 8.8.8.8 or 1.1.1.1 gives a good idea of your general link quality. |
@packet-loss-ping_count | 6 | Number of pings per statistics update. |
@packet-loss-history_size | 6 | Number of results to keep when displaying loss statistics. Keeping this value low is recommended since it's more useful to see current status over long-term averages. For a historical overview, use @packet-loss-hist_avg_display . |
@packet-loss-weighted_average | yes | yes Use weighted average focusing on the latest data points.no Average over all data points. |
@packet-loss-display_trend | no | yes Display trend with + prefix for higher levels and - prefix for lower levels.no Do not indicate change since the previous loss level. |
@packet-loss-hist_avg_display | no | yes Show historical average when displaying current losses.no Do not show historical average. |
@packet-loss-run_disconnected | no | yes monitor only exits when tmux is shut down.no monitor exits if no clients are connected and restarts when a client re-connects. |
@packet-loss-level_disp | 1 | Display loss if at or higher than this level. |
@packet-loss-level_alert | 17 | Color loss with color_alert if at or above this level.Suggestion: set it one higher than the percentage representing one loss in one update to avoid single packet loss triggering an alert initially. |
@packet-loss-level_crit | 40 | Color loss with color_crit if at or above this level. |
@packet-loss-hist_avg_minutes | 30 | Minutes to keep the historical average. |
@packet-loss-hist_separator | '~' | Separator for current/historical losses. |
@packet-loss-color_alert | colour226 | Use this color if the loss is at or above @packet-loss-level_alert . |
@packet-loss-color_crit | colour196 | Use this color if the loss is at or above @packet-loss-level_crit . |
@packet-loss-color_bg | black | Background color when alert/crit colors are used in the display. |
@packet-loss-prefix | '|' | Prefix for status when displayed. |
@packet-loss-suffix | '|' | Suffix for status when displayed. |
@packet-loss-log_file | If defined this file will be used for logging. |
set -g @packet-loss-display_trend yes
set -g @packet-loss-hist_avg_display yes
#
# In combination with weighted_average, ping_count and history_size,
# This makes a single ping loss disappear from being displayed in 15s
#
set -g @packet-loss-level_disp 5
set -g @packet-loss-color_alert colour21
set -g @packet-loss-color_bg colour226
To obtain a clearer picture of the current situation, consider adjusting the ping count. A higher ping count results in more nuanced data per check. For instance, if only 2 packets are checked per round, the results may only be 0%, 50%, or 100%, lacking granularity. Increasing the ping count enhances the accuracy of each check.
However, be cautious not to exceed a certain limit, as a higher ping count prolongs the time taken for each test. This delay may render the reported data irrelevant to the current link status, particularly if your focus is on real-time monitoring.
For longer-term averages, it is better to use @packet-loss-hist_avg_display
Additionally, it's advisable to review and potentially adjust the status-interval
setting to align with your reporting needs. Ensuring that the update rate for
this plugin in the status bar remains relevant enhances the effectiveness of your
monitoring system.
Given that ping is instantaneous, consider setting the status-interval
to one
lower than @packet-loss-ping_count
. This adjustment synchronizes the sampling
and reporting processes more effectively, providing timely and accurate updates.
If the data folder, where the database and status files are kept disappears, the database and statuses will be recreated and a new monitor process will be started. So this is a simple and quick way to clear historical data, without having to bother with SQL!
If @packet-loss-weighted_average
is set to yes (the default) losses
are displayed as the largest of:
- last value
- avg of last 2
- avg of last 3
- avg of last 4
- avg of last 5
- avg of last 6
- avg of last 7
- avg of all
If set to no, the average of all samples is always displayed.
Depending on the ping count, it is suggested to set an alert, so that a single lost packet won't show up as an alert.
pings | one higher than a single loss % |
history size for aprox 30s |
---|---|---|
10 | 11 | 3 (27) 4 (36) |
9 | 12 | 4 (32) |
8 | 13 | 5 (35) |
7 | 15 | 5 (30) |
6 (default) | 17 | 6 (30) |
5 | 21 | 8 (32) |
3 | 34 | 15 (30) |
There are three tables
table | Description |
---|---|
t_loss | Contains the current loss statuses |
t_1_min | Keeps all samples from the last minute, to feed one-minute averages to the t_stats table |
t_stats | Keeps one-minute averages for the last @packet-loss-hist_avg_minutes minutes |
Each table contains two fields, time_stamp, and value. The time_stamp field is used to purge old records.
To examine the plugin displaying losses in the status bar, there is an included test script. Run it without params to get a help summary
./scripts/test_data.sh
The monitor will be automatically restarted two minutes after the last run of
test_data
.
Contributions are welcome, and they're appreciated. Every little bit helps, and credit is always given.
The best way to send feedback is to file an issue at tmux-packet-loss/issues