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: helm concurrent deploys with cross dependency #9588

Conversation

orlandoburli
Copy link

@orlandoburli orlandoburli commented Nov 28, 2024

Fixes: #5417

Description
This PR is adding a option for concurrent helm releases to wait for other helm charts.

deploy:
  helm:
    concurrency: 3
    releases:
      - name: service1
        chartPath: charts/service1
      - name: service2
        chartPath: charts/service2
      - name: service3
        chartPath: charts/service3
        dependsOn:
          - service1
          - service2

On the following example, the service3 will wait until helm deploy for service1 and service2 to finish. If some of those services fails, the service3 deployment won't start.

User facing changes

User can add the dependsOn option to a helm release template.

Copy link

google-cla bot commented Nov 28, 2024

Thanks for your pull request! It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA).

View this failed invocation of the CLA check for more information.

For the most up to date status, view the checks section at the bottom of the pull request.

@orlandoburli orlandoburli changed the title Feat/helm deploys cross dependency feat: helm deploys cross dependency Nov 28, 2024
@orlandoburli orlandoburli force-pushed the feat/helm-deploys-cross-dependency branch from 5049354 to 15a88c1 Compare November 28, 2024 05:31
@orlandoburli orlandoburli force-pushed the feat/helm-deploys-cross-dependency branch from 15a88c1 to 88599a4 Compare November 28, 2024 05:37
@orlandoburli orlandoburli changed the title feat: helm deploys cross dependency feat: helm concurrent deploys with cross dependency Nov 28, 2024
@@ -295,8 +307,33 @@ func (h *Deployer) Deploy(ctx context.Context, out io.Writer, builds []graph.Art
return helm.UserErr(fmt.Sprintf("cannot expand chart path %q", r.ChartPath), err)
}

for _, dependency := range r.DependsOn {
Copy link
Contributor

Choose a reason for hiding this comment

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

what about nested dependencies?
ServiceA depends on ServiceB and ServiceB depends on Service C

Copy link
Author

Choose a reason for hiding this comment

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

I have not created a test for this case but, in theory, it should work the same way. Here's why:

  • The first action is to check all services that has dependents, then create the channels to use as wait controllers;
  • So, In the case you're suggesting:
    • If ServiceC starts first, it will hit the signal break with channels; It's gonna wait for Service B to continue;
    • If ServiceB starts in second, it will hit the signal break too, and wait for ServiceA
    • ServiceA does not depends on anyone, so it deploys and send the "all clear" signal to his dependents
    • ServiceB get's the "all clear" signal, and starts this deployment. When finished, it will also sends his signal for ServiceC
    • Finally, ServiceC get's his all clear and do this deployment.

One scenario that may happen is a deadlock. I did not think about it on this PR.

Another thing that I'm thinking is that this deserve a integration testing. I'm still learning about this repo and I will create a separated PR for that. This PR already has the label "size/L" 😱

Copy link
Contributor

Choose a reason for hiding this comment

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

I suggest you to check this approach #9588 (comment), because the current approach will lead to deadlock(concurrency = 3 and 3 dependencies are waiting, for example).
don't worry about the "size/L", it's ok)

Copy link
Author

Choose a reason for hiding this comment

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

Ok thanks for the feedback @idsulik . I'll work on that. Now I see the point, it's easy to get to a deadlock situation because of the lack of resources.

@idsulik
Copy link
Contributor

idsulik commented Nov 28, 2024

@orlandoburli welcome! good feature!
I think you can use topological sorting to achieve this or a simpler way:

  1. put releases in some data structure to extract them level by level.
  2. lock each level using semaphore.

flow:

  1. start installing deepest level dependencies
  2. lock until all the releases will be installed
  3. start installing next level dependencies
  4. lock
  5. etc.

Copy link

codecov bot commented Dec 13, 2024

Codecov Report

Attention: Patch coverage is 81.25000% with 6 lines in your changes missing coverage. Please review.

Project coverage is 63.17%. Comparing base (290280e) to head (88599a4).
Report is 1237 commits behind head on main.

Files with missing lines Patch % Lines
pkg/skaffold/deploy/helm/helm.go 81.25% 3 Missing and 3 partials ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #9588      +/-   ##
==========================================
- Coverage   70.48%   63.17%   -7.31%     
==========================================
  Files         515      648     +133     
  Lines       23150    33639   +10489     
==========================================
+ Hits        16317    21253    +4936     
- Misses       5776    10728    +4952     
- Partials     1057     1658     +601     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@alphanota alphanota self-assigned this Dec 17, 2024
@mepi262
Copy link

mepi262 commented Dec 18, 2024

@orlandoburli
It seems that some checks are not successful.
Would you confirm it?

@orlandoburli
Copy link
Author

@orlandoburli It seems that some checks are not successful. Would you confirm it?

Hey @mepi262 yes, I saw that. I will implement first the suggestion made by @idsulik before I jump into this. But thanks for the heads up.

@mepi262
Copy link

mepi262 commented Dec 19, 2024

@orlandoburli
I'm looking forward to this feature and I hope this project will be success and be released.
Thank you for your reply!

@idsulik
Copy link
Contributor

idsulik commented Dec 20, 2024

I've implemented this idea #9588 (comment) within this PR #9624

@orlandoburli I'll close my PR if you'd prefer to implement it yourself, just let me know! because you started it first)
If you want to keep my PR, then could you please check the implementation, if it works for you or not

@orlandoburli
Copy link
Author

I've implemented this idea #9588 (comment) within this PR #9624

@orlandoburli I'll close my PR if you'd prefer to implement it yourself, just let me know! because you started it first) If you want to keep my PR, then could you please check the implementation, if it works for you or not

Hey @idsulik let's go with your's PR, I didn't had the time to do it yet.

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.

Run helm concurrently
4 participants