Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

plugin entry collection_jitter doesn't take precedence over [agent] collection_jitter #15227

Closed
iridos opened this issue Apr 25, 2024 · 5 comments · Fixed by #15363
Closed

plugin entry collection_jitter doesn't take precedence over [agent] collection_jitter #15227

iridos opened this issue Apr 25, 2024 · 5 comments · Fixed by #15363
Labels
bug unexpected problem or unintended behavior

Comments

@iridos
Copy link

iridos commented Apr 25, 2024

Relevant telegraf.conf

  1. non-working example
[global_tags]
[agent]
  interval = "60s"
  round_interval = true
  collection_jitter = "10s"
  omit_hostname = true
[[ inputs.exec]]
   interval = "10s"
   collection_jitter = "0s"
   collection_offset = "0s"
   commands = [
      "/etc/telegraf/scripts/write-date"
   ]
   timeout = "5s"
   data_format = "influx"
[[outputs.file]]
  files = ["stdout", "/tmp/metrics.out"]
  1. working example with config like in 1) collection_jitter = "10s" removed from config
  2. date showing script (just to have time in output directly)
#!/bin/bash
echo "test-output,date=$(date -Is|sed 's/[+].*//') value=1"

Logs from Telegraf

  1. run with config of 1):
# /usr/bin/telegraf  -config /etc/telegraf/telegraf-test.conf 
2024-04-25T07:42:29Z I! Loading config: /etc/telegraf/telegraf-test.conf
2024-04-25T07:42:29Z I! Starting Telegraf 1.30.1 brought to you by InfluxData the makers of InfluxDB
2024-04-25T07:42:29Z I! Available plugins: 233 inputs, 9 aggregators, 31 processors, 24 parsers, 60 outputs, 6 secret-stores
2024-04-25T07:42:29Z I! Loaded inputs: exec
2024-04-25T07:42:29Z I! Loaded aggregators: 
2024-04-25T07:42:29Z I! Loaded processors: 
2024-04-25T07:42:29Z I! Loaded secretstores: 
2024-04-25T07:42:29Z I! Loaded outputs: file
2024-04-25T07:42:29Z I! Tags enabled: 
2024-04-25T07:42:29Z I! [agent] Config: Interval:1m0s, Quiet:false, Hostname:"", Flush Interval:10s
test-output,date=2024-04-25T09:42:35 value=1 1714030956000000000
test-output,date=2024-04-25T09:42:42 value=1 1714030963000000000
test-output,date=2024-04-25T09:42:54 value=1 1714030974000000000
test-output,date=2024-04-25T09:43:09 value=1 1714030989000000000
test-output,date=2024-04-25T09:43:11 value=1 1714030991000000000
test-output,date=2024-04-25T09:43:23 value=1 1714031003000000000
^C2024-04-25T07:43:31Z I! [agent] Hang on, flushing any cached metrics before shutdown
2024-04-25T07:43:31Z I! [agent] Stopping running outputs
  1. run with agent's collection jitter removed
# /usr/bin/telegraf  -config /etc/telegraf/telegraf-test.conf 
2024-04-25T07:47:32Z I! Loading config: /etc/telegraf/telegraf-test.conf
2024-04-25T07:47:32Z I! Starting Telegraf 1.30.1 brought to you by InfluxData the makers of InfluxDB
2024-04-25T07:47:32Z I! Available plugins: 233 inputs, 9 aggregators, 31 processors, 24 parsers, 60 outputs, 6 secret-stores
2024-04-25T07:47:32Z I! Loaded inputs: exec
2024-04-25T07:47:32Z I! Loaded aggregators: 
2024-04-25T07:47:32Z I! Loaded processors: 
2024-04-25T07:47:32Z I! Loaded secretstores: 
2024-04-25T07:47:32Z I! Loaded outputs: file
2024-04-25T07:47:32Z I! Tags enabled: 
2024-04-25T07:47:32Z I! [agent] Config: Interval:1m0s, Quiet:false, Hostname:"", Flush Interval:10s
test-output,date=2024-04-25T09:47:40 value=1 1714031260000000000
test-output,date=2024-04-25T09:47:50 value=1 1714031270000000000
test-output,date=2024-04-25T09:48:00 value=1 1714031280000000000
test-output,date=2024-04-25T09:48:10 value=1 1714031290000000000
test-output,date=2024-04-25T09:48:20 value=1 1714031300000000000

System info

Telegraf 1.30.1

Docker

No response

Steps to reproduce

  1. use config 1) from above, which uses collection_jittter in [agent] configuration and in a plugin (here exec plugin) configuration

...

Expected behavior

https://github.com/influxdata/telegraf/blob/master/docs/CONFIGURATION.md#intervals

collection_jitter: Overrides the collection_jitter setting of the [agent] (https://github.com/influxdata/telegraf/blob/master/docs/CONFIGURATION.md#agent) for the plugin. Collection jitter is used to jitter the collection by a random [interval]

Actual behavior

when [agent] configures jitter 10s and plugin configures jitter 0s, we see jitter in test output (see output "logs" section)

Additional info

No response

@iridos iridos added the bug unexpected problem or unintended behavior label Apr 25, 2024
@srebhan
Copy link
Member

srebhan commented Apr 25, 2024

@iridos actually, the plugin's option has precedence _if and only if it is not zero. :-( So setting the jitter to e.g. one nanosecond will override the agent's setting. This, or defining the jitter per plugin keeping the agent's setting zero, is the only workaround I can offer.

Solving this issue would involving a massive restructuring of the configuration handling as we currently instantiate plugins as we load the configs and we cannot guarantee the agent section to be loaded first, so we cannot complete the plugin's configuration (including agent-level settings) on instantiation...

@iridos
Copy link
Author

iridos commented Apr 25, 2024

Oh, ok. This might be something to put into the documentation, though.

@srebhan
Copy link
Member

srebhan commented Apr 25, 2024

I do agree. Would you be willing to submit a PR?

@iridos
Copy link
Author

iridos commented Apr 26, 2024

mh, I can try. But I am not too familiar with git and nor with the documentation structure.
I have taken CONFIGURATION.md to be the final authorative source of documentation, not sure what else there is.

@powersj
Copy link
Contributor

powersj commented Apr 26, 2024

I have taken CONFIGURATION.md to be the final authorative source of documentation, not sure what else there is.

That would be the primary place to update. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug unexpected problem or unintended behavior
Projects
None yet
3 participants