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

MCO-1505: allows user-configurable resource requests and limits via MachineOSConfig annotations #4946

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

cheesesashimi
Copy link
Member

@cheesesashimi cheesesashimi commented Mar 25, 2025

- What I did

To allow resource requests and limits to be set for on-cluster layering (OCL), I added the capability of setting these values via an annotation on the MachineOSConfig object. Additionally, in the absence of these annotations being set, we now have a default resource request set that mirrors the resource requests of the rest of the MCO's components.

- How to verify it

  1. Bring up an OCL-enabled cluster.
  2. Set any of the following annotations on a MachineOSConfig:
    • machineconfiguration.openshift.io/cpu-request
    • machineconfiguration.openshift.io/cpu-limit
    • machineconfiguration.openshift.io/memory-request
    • machineconfiguration.openshift.io/memory-limit
    • machineconfiguration.openshift.io/storage-request
    • machineconfiguration.openshift.io/storage-limit
    • machineconfiguration.openshift.io/ephemeral-storage-request
    • machineconfiguration.openshift.io/ephemeral-storage-limit
  3. Trigger a new build.
  4. The containers on the pod where the new MachineOSBuild is running should have those resource requests / limits set.

In the absence of those values being set, CPU should be set to 20m and memory should be set to 50Mi. The default resource request values are the same as the ones applied to the various MCO components.

- Description for the changelog
Allows user-configurable resource requests and limits via MachineOSConfig annotations

@openshift-ci-robot openshift-ci-robot added the jira/valid-reference Indicates that this PR references a valid Jira ticket of any type. label Mar 25, 2025
@openshift-ci-robot
Copy link
Contributor

openshift-ci-robot commented Mar 25, 2025

@cheesesashimi: This pull request references MCO-1505 which is a valid jira issue.

Warning: The referenced jira issue has an invalid target version for the target branch this PR targets: expected the story to target the "4.19.0" version, but no target version was set.

In response to this:

- What I did

To allow resource requests and limits to be set for on-cluster layering (OCL), I added the capability of setting these values via an annotation on the MachineOSConfig object. Additionally, in the absence of these annotations being set, we now have a default resource request set that mirrors the resource requests of the rest of the MCO's components.

- How to verify it

  1. Bring up an OCL-enabled cluster.
  2. Set any of the following annotations on a MachineOSConfig:
    • machineconfiguration.openshift.io/cpu-request
    • machineconfiguration.openshift.io/cpu-limit
    • machineconfiguration.openshift.io/memory-request
    • machineconfiguration.openshift.io/memory-limit
    • machineconfiguration.openshift.io/storage-request
    • machineconfiguration.openshift.io/storage-limit
    • machineconfiguration.openshift.io/ephemeral-storage-request
    • machineconfiguration.openshift.io/ephemeral-storage-limit
  3. Trigger a new build.
  4. The containers on the pod where the new MachineOSBuild is running should have those resource requests / limits set.

In the absence of those values being set, CPU should be set to 20m and memory should be set to 50Mi.

- Description for the changelog
Allows user-configurable resource requests and limits via MachineOSConfig annotations

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the openshift-eng/jira-lifecycle-plugin repository.

@openshift-ci openshift-ci bot added the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Mar 25, 2025
Copy link
Contributor

openshift-ci bot commented Mar 25, 2025

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

Copy link
Contributor

openshift-ci bot commented Mar 25, 2025

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: cheesesashimi

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@openshift-ci openshift-ci bot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Mar 25, 2025
@openshift-ci-robot
Copy link
Contributor

openshift-ci-robot commented Mar 26, 2025

@cheesesashimi: This pull request references MCO-1505 which is a valid jira issue.

Warning: The referenced jira issue has an invalid target version for the target branch this PR targets: expected the story to target the "4.19.0" version, but no target version was set.

In response to this:

- What I did

To allow resource requests and limits to be set for on-cluster layering (OCL), I added the capability of setting these values via an annotation on the MachineOSConfig object. Additionally, in the absence of these annotations being set, we now have a default resource request set that mirrors the resource requests of the rest of the MCO's components.

- How to verify it

  1. Bring up an OCL-enabled cluster.
  2. Set any of the following annotations on a MachineOSConfig:
    • machineconfiguration.openshift.io/cpu-request
    • machineconfiguration.openshift.io/cpu-limit
    • machineconfiguration.openshift.io/memory-request
    • machineconfiguration.openshift.io/memory-limit
    • machineconfiguration.openshift.io/storage-request
    • machineconfiguration.openshift.io/storage-limit
    • machineconfiguration.openshift.io/ephemeral-storage-request
    • machineconfiguration.openshift.io/ephemeral-storage-limit
  3. Trigger a new build.
  4. The containers on the pod where the new MachineOSBuild is running should have those resource requests / limits set.

In the absence of those values being set, CPU should be set to 20m and memory should be set to 50Mi. The default resource request values are the same as the ones applied to the various MCO components.

- Description for the changelog
Allows user-configurable resource requests and limits via MachineOSConfig annotations

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the openshift-eng/jira-lifecycle-plugin repository.

@cheesesashimi cheesesashimi marked this pull request as ready for review March 26, 2025 15:53
@openshift-ci openshift-ci bot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Mar 26, 2025
@openshift-ci openshift-ci bot requested review from djoshy and yuqi-zhang March 26, 2025 15:54
@cheesesashimi cheesesashimi force-pushed the zzlotnik/ocl-resource-requests branch 3 times, most recently from ceb45c6 to ee2b811 Compare March 26, 2025 21:41
@cheesesashimi cheesesashimi force-pushed the zzlotnik/ocl-resource-requests branch from ee2b811 to bee5f07 Compare March 26, 2025 22:23
Copy link
Contributor

openshift-ci bot commented Mar 27, 2025

@cheesesashimi: The following tests failed, say /retest to rerun all failed tests or /retest-required to rerun all mandatory failed tests:

Test name Commit Details Required Rerun command
ci/prow/e2e-gcp-op-ocl bee5f07 link false /test e2e-gcp-op-ocl
ci/prow/e2e-aws-ovn-upgrade-out-of-change bee5f07 link false /test e2e-aws-ovn-upgrade-out-of-change
ci/prow/e2e-azure-ovn-upgrade-out-of-change bee5f07 link false /test e2e-azure-ovn-upgrade-out-of-change
ci/prow/e2e-aws-ovn-upgrade bee5f07 link true /test e2e-aws-ovn-upgrade
ci/prow/okd-scos-e2e-aws-ovn bee5f07 link false /test okd-scos-e2e-aws-ovn
ci/prow/e2e-aws-ovn bee5f07 link true /test e2e-aws-ovn

Full PR test history. Your PR dashboard.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. I understand the commands that are listed here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. jira/valid-reference Indicates that this PR references a valid Jira ticket of any type.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants