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

[system][process] Add metric_type metadata for object fields, set stack restriction to 8.9.0 version #7660

Conversation

tetianakravchenko
Copy link
Contributor

What does this PR do?

It is a follow up of this PR comment - #6493 (review)
to add all missing metric_type.

Checklist

  • I have reviewed tips for building integrations and this pull request is aligned with them.
  • I have verified that all data streams collect metrics or logs.
  • I have added an entry to my package's changelog.yml file.
  • I have verified that Kibana version constraints are current according to guidelines.

Author's Checklist

  • [ ]

How to test this PR locally

Related issues

Screenshots

@tetianakravchenko tetianakravchenko requested review from a team as code owners September 5, 2023 06:41
@elasticmachine
Copy link

elasticmachine commented Sep 5, 2023

💚 Build Succeeded

the below badges are clickable and redirect to their specific view in the CI or DOCS
Pipeline View Test View Changes Artifacts preview preview

Expand to view the summary

Build stats

  • Start Time: 2023-09-27T07:35:21.633+0000

  • Duration: 16 min 38 sec

Test stats 🧪

Test Results
Failed 0
Passed 151
Skipped 0
Total 151

🤖 GitHub comments

Expand to view the GitHub comments

To re-run your PR in the CI, just comment with:

  • /test : Re-trigger the build.

@elasticmachine
Copy link

elasticmachine commented Sep 5, 2023

🌐 Coverage report

Name Metrics % (covered/total) Diff
Packages 100.0% (3/3) 💚
Files 100.0% (4/4) 💚 5.556
Classes 100.0% (4/4) 💚 5.556
Methods 63.415% (52/82) 👎 -22.539
Lines 99.863% (2924/2928) 👍 13.84
Conditionals 100.0% (0/0) 💚

- version: "1.39.0"
changes:
- description: Add metric_type metadata for object fields, set stack restriction to 8.9.0 version
type: bugfix
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

enhancement?

Copy link
Collaborator

@lalit-satapathy lalit-satapathy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@@ -541,11 +542,10 @@
description: >
The number of times that the memory limit (kmem_tcp.limit.bytes) was reached.

- name: stats.*
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tetianakravchenko, Any reason we are removing the mapping in multiple places for stats.* and we are only keeping the ones with stats.*.bytes

How will be the following field be mapped: system.process.cgroup.memory.stats.page_faults

Can we check the mapping of all the stats group under system.process ?

Copy link
Contributor Author

@tetianakravchenko tetianakravchenko Sep 26, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@lalit-satapathy I am not sure why we initially had stats.* format.

all metrics that includes * in the name are included now in dynamic_templates:
Screenshot 2023-09-25 at 16 44 26

How will be the following field be mapped: system.process.cgroup.memory.stats.page_faults

system.process.cgroup.memory.stats.page_faults is defined here -

- name: stats.page_faults
type: long
metric_type: counter
description: >
Number of times that a process in the cgroup triggered a page fault.

mapping for this field:
Screenshot 2023-09-25 at 16 52 23

Can we check the mapping of all the stats group under system.process ?

Stats object mapping under `system.process.cgroup.memory`
 "stats": {
                          "properties": {
                            "active_anon": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "active_file": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "anon": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "anon_thp": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "cache": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "file": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "file_dirty": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "file_mapped": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "file_thp": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "file_writeback": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "hierarchical_memory_limit": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "hierarchical_memsw_limit": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "htp_collapse_alloc": {
                              "type": "long"
                            },
                            "inactive_anon": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "inactive_file": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "kernel_stack": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "major_page_faults": {
                              "type": "long",
                              "time_series_metric": "counter"
                            },
                            "mapped_file": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "page_activate": {
                              "type": "long"
                            },
                            "page_deactivate": {
                              "type": "long"
                            },
                            "page_faults": {
                              "type": "long",
                              "time_series_metric": "counter"
                            },
                            "page_lazy_free": {
                              "type": "long"
                            },
                            "page_lazy_freed": {
                              "type": "long"
                            },
                            "page_refill": {
                              "type": "long"
                            },
                            "page_scan": {
                              "type": "long"
                            },
                            "page_steal": {
                              "type": "long"
                            },
                            "page_tables": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "pages_in": {
                              "type": "long",
                              "time_series_metric": "counter"
                            },
                            "pages_out": {
                              "type": "long",
                              "time_series_metric": "counter"
                            },
                            "per_cpu": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "rss": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "rss_huge": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "shmem": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "shmem_thp": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "slab": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "slab_reclaimable": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "slab_unreclaimable": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "sock": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "swap": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "swap_cached": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "thp_fault_alloc": {
                              "type": "long"
                            },
                            "unevictable": {
                              "properties": {
                                "bytes": {
                                  "type": "long",
                                  "time_series_metric": "gauge"
                                }
                              }
                            },
                            "workingset_activate_anon": {
                              "type": "long"
                            },
                            "workingset_activate_file": {
                              "type": "long"
                            },
                            "workingset_node_reclaim": {
                              "type": "long"
                            },
                            "workingset_refault_anon": {
                              "type": "long"
                            },
                            "workingset_refault_file": {
                              "type": "long"
                            },
                            "workingset_restore_anon": {
                              "type": "long"
                            },
                            "workingset_restore_file": {
                              "type": "long"
                            }
                          }
                        }

One thing I noticed that some fields are not defined in the fields folder and for this reason they are missing time_series_metric. I think it is fields that were added in this PR - elastic/beats#27242.

I think there should be another PR for adding missing fields, to not mix it up in this PR

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @fearful-symmetry I see that this field was introduced in this PR - #1539 by you, could you please check if I am missing here something? I don't really understand why this was initially introduced, in addition to the stats.*.bytes - https://github.com/elastic/integrations/pull/1539/files#diff-c594e593105a59a8530cec1e0670442dbe7b2cc59074900a65b96e6b4f95352fR481-R483

@lalit-satapathy
Copy link
Collaborator

all metrics that includes * in the name are included now in dynamic_templates:

It will be good, if we confirm that no fields are left un-mapped because we removed stats.*, stats.*.* mappings. Otherwise LGTM.

Copy link
Contributor

@ritalwar ritalwar left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@tetianakravchenko
Copy link
Contributor Author

@lalit-satapathy

It will be good, if we confirm that no fields are left un-mapped because we removed stats., stats..* mappings. Otherwise LGTM.

can you please explain how do you want me to confirm it?
I think it is not even possible to get unmapped fields since by default is used dynamic mapping

I've checked the latest system package version running in cloud (so without my changes):
Screenshot 2023-09-27 at 12 11 06

so fields stats.* are mapped either as defined in fields file - example page_faults https://github.com/elastic/integrations/blob/main/packages/system/data_stream/process/fields/fields.yml#L602-L625 or defined by the dynamic mapping - note that some fields like page_activate are not defined in the fields file, but are exposed by the beats - https://github.com/elastic/beats/blob/main/metricbeat/module/system/process/_meta/data.json#L170

On my local setup with the version that include changes in this PR:
Screenshot 2023-09-27 at 12 19 13

you can see that both mentioned fields are present as well - page_activate (not defined in list of fields) and page_faults (defined in list of fields)

Copy link
Collaborator

@lalit-satapathy lalit-satapathy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@tetianakravchenko tetianakravchenko merged commit ff961b5 into elastic:main Sep 27, 2023
@elasticmachine
Copy link

Package system - 1.40.0 containing this change is available at https://epr.elastic.co/search?package=system

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants