telegraf/plugins/inputs/internet_speed
r3inbowari c1f355d577
chore(deps): Bump github.com/showwin/speedtest-go from 1.7.5 to 1.7.6 (#15362)
2024-05-15 13:24:54 -05:00
..
README.md feat(inputs.internet_speed): Introduce packet loss field (#15329) 2024-05-10 09:22:14 -06:00
internet_speed.go chore(deps): Bump github.com/showwin/speedtest-go from 1.7.5 to 1.7.6 (#15362) 2024-05-15 13:24:54 -05:00
internet_speed_test.go chore(deps): Bump github.com/showwin/speedtest-go from 1.6.6 to 1.6.7 (#14250) 2023-11-10 12:27:37 +01:00
sample.conf feat(inputs.internet_speed): Introduce packet loss field (#15329) 2024-05-10 09:22:14 -06:00

README.md

Internet Speed Monitor Input Plugin

The Internet Speed Monitor collects data about the internet speed on the system.

On some systems, the default settings may cause speed tests to fail; if this affects you then try enabling memory_saving_mode. This reduces the memory requirements for the test, and may reduce the runtime of the test. However, please be aware that this may also reduce the accuracy of the test for fast (>30Mb/s) connections. This setting enables the upstream Memory Saving Mode

Global configuration options

In addition to the plugin-specific configuration settings, plugins support additional global and plugin configuration settings. These settings are used to modify metrics, tags, and field or create aliases and configure ordering, etc. See the CONFIGURATION.md for more details.

Configuration

# Monitors internet speed using speedtest.net service
[[inputs.internet_speed]]
  ## This plugin downloads many MB of data each time it is run. As such
  ## consider setting a higher interval for this plugin to reduce the
  ## demand on your internet connection.
  # interval = "60m"

  ## Enable to reduce memory usage
  # memory_saving_mode = false

  ## Caches the closest server location
  # cache = false

  ## Number of concurrent connections
  ## By default or set to zero, the number of CPU cores is used. Use this to
  ## reduce the impact on system performance or to increase the connections on
  ## faster connections to ensure the fastest speed.
  # connections = 0

  ## Test mode
  ## By default, a single sever is used for testing. This may work for most,
  ## however, setting to "multi" will reach out to multiple servers in an
  ## attempt to get closer to ideal internet speeds.
  ## And "multi" will use all available servers to calculate average packet loss.
  # test_mode = "single"

  ## Server ID exclude filter
  ## Allows the user to exclude or include specific server IDs received by
  ## speedtest-go. Values in the exclude option will be skipped over. Values in
  ## the include option are the only options that will be picked from.
  ##
  ## See the list of servers speedtest-go will return at:
  ##     https://www.speedtest.net/api/js/servers?engine=js&limit=10
  ##
  # server_id_exclude = []
  # server_id_include = []

Metrics

It collects the following fields:

Name Field Name Type Unit
Download Speed download float64 Mbps
Upload Speed upload float64 Mbps
Latency latency float64 ms
Jitter jitter float64 ms
Packet Loss packet_loss float64 percentage
Location location string -

The packet_loss will return -1, if packet loss not applicable.

And the following tags:

Name tag name
Source source
Server ID server_id
Test Mode test_mode

Example Output

internet_speed,source=speedtest02.z4internet.com:8080,server_id=54619,test_mode=single download=318.37580265897725,upload=30.444407341274385,latency=37.73174,jitter=1.99810,packet_loss=0.05377,location="Somewhere, TX" 1675458921000000000
internet_speed,source=speedtest02.z4internet.com:8080,server_id=54619,test_mode=multi download=318.37580265897725,upload=30.444407341274385,latency=37.73174,jitter=1.99810,packet_loss=-1,location="Somewhere, TX" 1675458921000000000