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

[8.13](backport #4371) [Kubernetes secret provider] Send signal to agent if cache is updated #4437

Merged
merged 2 commits into from
Mar 19, 2024

Conversation

mergify[bot]
Copy link
Contributor

@mergify mergify bot commented Mar 19, 2024

What does this PR do?

If the secrets in the cache get updated, then we notify the agent.

Why is it important?

See issue #4168 and the comments there.

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/fragments using the changelog tool
  • I have added an integration test or an E2E test

How to test this PR locally

Check the README file in the root directory to see how to build your own custom image and loaded to kind cluster.

Example secret.
apiVersion: v1
kind: Secret
metadata:
  name: my-secret
data:
  extra: bXktc2VjcmV0LW1lc3NhZ2UK
Example input that you can add to EA standalone using the secret.
      - id: kubernetes-node-metrics
        type: kubernetes/metrics
        use_output: default
        meta:
          package:
            name: kubernetes
            version: 1.52.0
        data_stream:
          namespace: default
        streams:
          - data_stream:
              dataset: kubernetes.proxy
              type: metrics
            metricsets:
              - proxy
            hosts:
              - 'localhost:10249'
            period: 10s
            processors:
              - add_fields:
                  target: myfield
                  fields:
                    value: ${kubernetes_secrets.default.my-secret.extra}

Related issues

Screenshots

Using the setup as in the section on how to test locally, we can check that the new field has the correct value associated with the secret:

image

Logs

If a secret gets updated, then the cache will be updated and this wall cause the signal to get triggered. Logs:

{"log.level":"info","@timestamp":"2024-03-07T12:07:46.095Z","log.logger":"composable","log.origin":{"file.name":"kubernetessecrets/kubernetes_secrets.go","file.line":119},"message":"Secrets cache was updated, the agent will be notified.","log":{"source":"elastic-agent"},"ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2024-03-07T12:07:46.273Z","log.origin":{"file.name":"coordinator/coordinator.go","file.line":1382},"message":"component model updated","log":{"source":"elastic-agent"},"changes":{"components":{"updated":["kubernetes/metrics-default: [(kubernetes/metrics-default-kubernetes-node-metrics: updated)]"],"count":4},"outputs":{}},"ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2024-03-07T12:07:46.273Z","log.origin":{"file.name":"coordinator/coordinator.go","file.line":1181},"message":"Updating running component model","log":{"source":"elastic-agent"},"ecs.version":"1.6.0"}

This is an automatic backport of pull request #4371 done by [Mergify](https://mergify.com).

…#4371)

* Send signal if cache is updated

* Signal tests

* Add changelog fragment and fix typos

* Update changelog/fragments/1709824109-k8s-secret-provider-trigger-signal.yaml

Co-authored-by: Blake Rouse <blake.rouse@elastic.co>

* Fix racing condition

---------

Co-authored-by: Blake Rouse <blake.rouse@elastic.co>
(cherry picked from commit 5326332)
@mergify mergify bot requested a review from a team as a code owner March 19, 2024 17:10
@mergify mergify bot added the backport label Mar 19, 2024
@mergify mergify bot requested review from michalpristas and pchila and removed request for a team March 19, 2024 17:10
@cmacknz
Copy link
Member

cmacknz commented Mar 19, 2024

Needs #4368 first

Copy link

@cmacknz cmacknz merged commit 16f1b24 into 8.13 Mar 19, 2024
9 checks passed
@cmacknz cmacknz deleted the mergify/bp/8.13/pr-4371 branch March 19, 2024 22:38
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.

2 participants