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

feat(k8s): discovery uses EndpointSlices instead of Endpoints #740

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

andrewazores
Copy link
Member

@andrewazores andrewazores commented Dec 9, 2024

Welcome to Cryostat! 👋

Before contributing, make sure you have:

  • Read the contributing guidelines
  • Linked a relevant issue which this PR resolves
  • Linked any other relevant issues, PR's, or documentation, if any
  • Resolved all conflicts, if any
  • Rebased your branch PR on top of the latest upstream main branch
  • Attached at least one of the following labels to the PR: [chore, ci, docs, feat, fix, test]
  • Signed all commits using a GPG signature

To recreate commits with GPG signature git fetch upstream && git rebase --force --gpg-sign upstream/main


Fixes: #717

Description of the change:

Replaces the Kubernetes API discovery mechanism's usage of the older Endpoints with the newer EndpointSlices. This should be functionally identical to the end Cryostat user and should record the same results in the database, it's only a slight internal logic change.

For early review and testing purposes, this PR currently retains the old Endpoints-based implementation and adds the new EndpointSlices-based implementation as a separate discovery plugin/realm, which is enabled by a different config property. This is so that it's possible to enable both at the same time on the same Cryostat instance and verify that they behave identically. Once that is validated then I will clean up this PR so that the new implementation simply replaces the old one as an internal implementation detail.

Motivation for the change:

This is a newer Kubernetes API feature and may have some performance benefits (fewer discovery update events?).~~ It opens the door for future improvements like using the EndpointSlices' readiness property to either gate target discoveryability, or to include that readiness data in the target record.~~ The EndpointSlices' "conditions" are embedded into the target definition as Cryostat annotations, ie. the target's readiness state can be determined.

How to manually test:

  1. Get a Kubernetes or OpenShift cluster
  2. Check out WIP EndpointSlices discovery cryostat-helm#226
  3. Create namespaces cryostat, apps1, and apps2. In each, use the Operator's Makefile to make sample_app to install a sample application to each namespace
  4. kubectl scale -n apps2 deployment quarkus-test --replicas=2
  5. Install Cryostat, using an image built from this PR: $ helm install --set core.image.repository=quay.io/andrewazores/cryostat --set core.image.tag=endpoint-slices-4 --set core.route.enabled=true --set core.discovery.kubernetes.namespaces='{cryostat,apps1,apps2}' --set core.discovery.kubernetes.enabled=false --set core.discovery.kubernetes2.enabled=true cryostat ./charts/cryostat (if not using OpenShift, turn off the core.route.enabled switch)
  6. Wait for Cryostat to be ready, then open its UI and go to Topology
  7. Verify that Cryostat discovers all the targets as usual, but using the new EndpointSlices discovery. When using the new discovery mechanism there should also be Cryostat annotations visible in the Topology view indicating the slices' conditions, ie readiness/serving/terminating:

image

  1. Flip back to the old discovery mechanism: helm upgrade --reuse-values --set core.discovery.kubernetes.enabled=true --set core.discovery.kubernetes2.enabled=false cryostat ./charts/cryostat
  2. Wait for Cryostat to be ready, then reopen the UI and verify that the Topology view looks essentially the same
  3. Use the kubectl scale command on different sample applications in each namespace to test the behaviour of both the old and new implementations. Both should behave the same way with target lost/found events.

@mergify mergify bot added the safe-to-test label Dec 9, 2024
@andrewazores andrewazores added the feat New feature or request label Dec 9, 2024
@andrewazores andrewazores changed the title fix(k8s): discovery uses EndpointSlices instead of Endpoints feat(k8s): discovery uses EndpointSlices instead of Endpoints Dec 9, 2024
@andrewazores andrewazores marked this pull request as ready for review December 9, 2024 21:11
@andrewazores andrewazores requested a review from a team December 9, 2024 21:11
@andrewazores
Copy link
Member Author

/build_test

Copy link

Workflow started at 12/20/2024, 9:28:27 AM. View Actions Run.

Copy link

No GraphQL schema changes detected.

Copy link

No OpenAPI schema changes detected.

Copy link

CI build and push: At least one test failed ❌
https://github.com/cryostatio/cryostat/actions/runs/12433156912

@andrewazores
Copy link
Member Author

^ failures are expected at this point since there are two side-by-side Kubernetes discovery mechanisms. Once this is reviewed and I clean it up those tests should go back to passing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat New feature or request safe-to-test
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Bug] k8s discovery should replace old Endpoints with EndpointSlices
1 participant