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

Fix bug with override path in cgroups #27620

Conversation

fearful-symmetry
Copy link
Contributor

@fearful-symmetry fearful-symmetry commented Aug 26, 2021

What does this PR do?

This is a fix for #27598

In cases where cgroupsHierarchyOverride is set to /, and ignoreRootCgroups is set, we'll just completely bypass any cgroups reporting.

Why is it important?

It's a bug that was breaking containers.

Checklist

  • My code follows the style guidelines of this project
  • I have commented my code, particularly in hard-to-understand areas
  • I have made corresponding changes to the documentation
  • I have made corresponding change to the default configuration files
  • I have added tests that prove my fix is effective or that my feature works
  • I have added an entry in CHANGELOG.next.asciidoc or CHANGELOG-developer.next.asciidoc.

How to test this PR locally

  • Build metricbeat (or any other beat) for docker
  • run on linux
  • set http.enabled to true in the beat config
  • From inside the docker container, do curl localhost:5066/stats?pretty
  • Make sure cgroup metrics are reported.

Related issues

@fearful-symmetry fearful-symmetry added bug Team:Integrations Label for the Integrations team backport-v7.15.0 Automated backport with mergify backport-v7.16.0 Automated backport with mergify labels Aug 26, 2021
@fearful-symmetry fearful-symmetry requested review from axw and a team August 26, 2021 21:35
@fearful-symmetry fearful-symmetry self-assigned this Aug 26, 2021
@elasticmachine
Copy link
Collaborator

Pinging @elastic/integrations (Team:Integrations)

@botelastic botelastic bot added needs_team Indicates that the issue/PR needs a Team:* label and removed needs_team Indicates that the issue/PR needs a Team:* label labels Aug 26, 2021
@elasticmachine
Copy link
Collaborator

elasticmachine commented Aug 27, 2021

💚 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: 2021-08-31T02:58:21.884+0000

  • Duration: 148 min 56 sec

  • Commit: 6f50223

Test stats 🧪

Test Results
Failed 0
Passed 53721
Skipped 5325
Total 59046

Trends 🧪

Image of Build Times

Image of Tests

💚 Flaky test report

Tests succeeded.

Expand to view the summary

Test stats 🧪

Test Results
Failed 0
Passed 53721
Skipped 5325
Total 59046

Copy link
Member

@axw axw left a comment

Choose a reason for hiding this comment

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

@matschaffer
Copy link
Contributor

Is there a handy place I can snag the linux binary? I should be able to test it on my cloud deployment.

@ruflin
Copy link
Contributor

ruflin commented Aug 30, 2021

@matschaffer Not before the merge of the PR. But I can build it for you or tell you how to build it ;-)

@fearful-symmetry
Copy link
Contributor Author

/test

@mergify
Copy link
Contributor

mergify bot commented Aug 30, 2021

This pull request is now in conflicts. Could you fix it? 🙏
To fixup this pull request, you can check out it locally. See documentation: https://help.github.com/articles/checking-out-pull-requests-locally/

git fetch upstream
git checkout -b cgroupsHierarchyOverride-logic-fix upstream/cgroupsHierarchyOverride-logic-fix
git merge upstream/master
git push upstream cgroupsHierarchyOverride-logic-fix

@matschaffer
Copy link
Contributor

@ruflin either way. Pretty sure you also have all the access you need to try to squeeze a build into a test deployment. Since @axw approved maybe we can just wait for the next BC.

@axw
Copy link
Member

axw commented Aug 31, 2021

FWIW, I tested this with this small program - ran it before/after changes in a Docker container:

package main

import (
        "fmt"
        "log"

        "github.com/elastic/beats/v7/libbeat/cmd/instance/metrics"
        "github.com/elastic/beats/v7/libbeat/monitoring"
)

func main() {
        if err := metrics.SetupMetrics("testing"); err != nil {
                log.Fatal(err)
        }
        snapshot := monitoring.CollectFlatSnapshot(monitoring.Default, monitoring.Full, false)
        for name, value := range snapshot.Ints {
                fmt.Println(name, value)
        }
}

I think we're good, and can just wait for the next BC after this merges.

@fearful-symmetry
Copy link
Contributor Author

Yep, sorry for the delay, once again fighting with CI...

@fearful-symmetry
Copy link
Contributor Author

/test

@fearful-symmetry
Copy link
Contributor Author

FINALLY

@fearful-symmetry fearful-symmetry merged commit f073c45 into elastic:master Aug 31, 2021
mergify bot pushed a commit that referenced this pull request Aug 31, 2021
* fix bug with override path

* add changelog

(cherry picked from commit f073c45)
mergify bot pushed a commit that referenced this pull request Aug 31, 2021
* fix bug with override path

* add changelog

(cherry picked from commit f073c45)
fearful-symmetry added a commit that referenced this pull request Aug 31, 2021
* fix bug with override path

* add changelog

(cherry picked from commit f073c45)

Co-authored-by: Alex K <[email protected]>
fearful-symmetry added a commit that referenced this pull request Aug 31, 2021
* fix bug with override path

* add changelog

(cherry picked from commit f073c45)

Co-authored-by: Alex K <[email protected]>
mdelapenya added a commit to mdelapenya/beats that referenced this pull request Sep 1, 2021
* master:
  Forward port 7.14.1 changelog to master  (elastic#27687)
  Addressing multiple dashboard issues: deps loading once, field conversion, etc. (elastic#27669)
  Remove adaptive queue sizes from agent's spec files (elastic#27653)
  Osquerybeat: Improve testability and unit test coverage (elastic#27591)
  Osquerybeat: lockdown flagsfile, prevent global defaults (elastic#27611)
  Import the references of dashboard assets using the Saved Objects API (elastic#27647)
  Fix bug with override path in cgroups (elastic#27620)
  Allow Kibana client to authorize with Elasticsearch API key (elastic#27540)
  Filebeat auditd: Fix Top Exec Commands dashboard visualization (elastic#27638)
  [elastic-agent] Fix docker tar.gz generation for complete image (elastic#27621)
  Follow up changes in dashboards in mage check && fix minor issue (elastic#27553)
  [Heartbeat] Fix bug where `enabled: false` is ignored. (elastic#27615)
  Support kube_state_metrics v2.0.0 (elastic#27552)
Icedroid pushed a commit to Icedroid/beats that referenced this pull request Nov 1, 2021
* fix bug with override path

* add changelog
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backport-v7.15.0 Automated backport with mergify backport-v7.16.0 Automated backport with mergify bug Team:Integrations Label for the Integrations team
Projects
None yet
Development

Successfully merging this pull request may close these issues.

libbeat/cmd/instance: cgroup metrics no longer being reported
5 participants