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

Run kpack-image-builder, job-task-runner and statefulset-runner as standalone Deployments #3522

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

Conversation

pbusko
Copy link
Contributor

@pbusko pbusko commented Oct 16, 2024

Is there a related GitHub Issue?

Fixes #3519
Fixes #3495

What is this change about?

Implementation for #3519 (and a fix for #3495)

Does this PR introduce a breaking change?

no

Acceptance Steps

Tag your pair, your PM, and/or team

@pbusko pbusko force-pushed the standalone-controllers branch 5 times, most recently from 4732231 to 7e4ba83 Compare October 21, 2024 08:51
@pbusko pbusko force-pushed the standalone-controllers branch from 7e4ba83 to 3f36248 Compare October 25, 2024 11:49
Copy link
Member

@danail-branekov danail-branekov left a comment

Choose a reason for hiding this comment

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

Overall, looks good, minor comments.

I played a bit with the change:

  • All tests pass
  • Manual testing looks good
  • Upgrade from 0.13 seems seamless, helm takes care of the new deployments nicely
  • Kind installer works

I was trying to reason about resource requirements and how they are affected by splitting controllers into multiple deployments:

Monolit controllers deployments

  • Requests
    cpu: 50m
    memory: 100Mi
  • Limits
    cpu: 1000m
    memory: 1Gi

Multiple controllers deployments

Controllers:

  • Requests
    cpu: 50m
    memory: 100Mi
  • Limits
    cpu: 1000m
    memory: 1Gi

Statefulset runner:

  • Requests
    cpu: 50m
    memory: 100Mi
  • Limits
    cpu: 1000m
    memory: 1Gi

Kpack builder:

  • Requests
    cpu: 50m
    memory: 100Mi
  • Limits
    cpu: 1000m
    memory: 1Gi

Task runner:

  • Requests
    cpu: 50m
    memory: 100Mi
  • Limits
    cpu: 1000m
    memory: 1Gi

Total:

  • Requests
    cpu: 200m
    memory: 400Mi
  • Limits
    cpu: 4000m
    memory: 4Gi

What I see is that with the default request/limit values, the multiple deployment model requires 4 times more resources in comparisson with the monolit deployment model. I wonder whether we could come up with reasonable defaults that total up to similar numbers

scripts/deploy-on-kind.sh Outdated Show resolved Hide resolved
scripts/deploy-on-kind.sh Show resolved Hide resolved
@pbusko pbusko force-pushed the standalone-controllers branch 3 times, most recently from 57242b8 to 4b1c144 Compare November 6, 2024 14:02
@georgethebeatle
Copy link
Member

@pbusko any thoughts on the comment by @danail-branekov above with regards to limits and requests?

@pbusko pbusko force-pushed the standalone-controllers branch from 4b1c144 to 7bd9984 Compare January 8, 2025 15:31
@pbusko
Copy link
Contributor Author

pbusko commented Jan 8, 2025

What I see is that with the default request/limit values, the multiple deployment model requires 4 times more resources in comparisson with the monolit deployment model. I wonder whether we could come up with reasonable defaults that total up to similar numbers

On the other hand we're talking about 200m CPU and 400mb requests in total, which should be doable on pretty much every workstation/VM (unless it's running on a toaster). Limits themselves should not harm, since they do not allocate anything.
We also should not forget that it's just the default values that can always be adjusted by the end user if needed.

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