-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
[receiver/windowsperfcountersreceiver] Update Windows performance counter to be able to better define metrics. #8259
Comments
cc @dashpole |
I think this points out a necessary change. It's not acceptable in the longer term that this receiver would produce metrics in such a generic and often inaccurate way. The proposal overall makes sense to me. A few observations / points of feedback:
The major open question to me is how best to not reinvent the wheel when it comes to defining metrics in yaml. It would be great if we can reuse mdatagen's yaml structure here. It is designed for the same purpose really, so seems suitable. It's not currently exported and I assume we'd want to extract it out of the @dmitryax, do you think Incorporating what I've proposed above, the updated config would look like: windowsperfcounters/other:
collection_interval: 1m
metadata:
cpu.time:
enabled: true
description: The foo of the bar.
unit: %
gauge:
value_type: int
attributes: [ time ]
perfcounters:
- object: "Processor"
instances: [1, 2]
counters:
- counter_name: "% Idle Time"
metric_name: cpu.time
attributes:
time: idle
- counter_name: "% Active Time"
metric_name: cpu.time
attributes:
time: active |
I'm not familiar with this receiver yet. Is there any issues to migrate it to metrics builder? I believe doing that already resolves a part of this issue. And to cover remaining parts of this issue, we can probably extend metrics builder functionality |
I don't think this receiver could use metrics builder because it does not collect predefined metrics. It is up to the user to specify which performance counters should be collected. Correspondingly, this change suggests that the user should be able to articulate the characteristics of the metric into which the counter is converted. |
But isn't the set of performance counters limited? Potentially we can define all of them as optional metrics, right?
I thinking if this is something that can be covered by additional features of the metrics builder |
I'm not a Windows expert but my understanding is that Windows Performance Counters are basically a metrics framework, akin to MBeans. There are many standard counters for Windows itself and many more for common applications like SQL Server. However, I'm not sure it's reasonable to try to describe all of them (though I certainly could be wrong). More importantly, I think Windows application developers can define and report their own counters. |
Ok makes sense. In that case we can apply the approach that you suggested. I'd say metadata API is stable enough for this. There are still may be small changes and additions to it tho |
Is your feature request related to a problem? Please describe.
The windows performance counter receiver doesn't give much control over the metrics that are defined to be pulled from the defined counters.
Describe the solution you'd like
Update the existing receiver to give more in depth configuration.
an example of what a new configuration could be:
Describe alternatives you've considered
There is the ability to apply transforms to the data to get it in the proper format but it seems better to be able to do it up front rather than establishing all metrics as double gauges and then having to transform them.
The text was updated successfully, but these errors were encountered: