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

[stable/locust] Add support for git sync #641

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

AlexisBRENON
Copy link

Description

Add Git Sync support to locust chart to easily deploy multiple locustfiles.

Checklist

  • Title of the PR starts with chart name (e.g. [stable/mychartname])
  • I have read the contribution instructions, bumped chart version and regenerated the docs
  • Github actions are passing

@AlexisBRENON AlexisBRENON requested a review from a team as a code owner December 16, 2024 10:27
@max-rocket-internet
Copy link
Member

Sorry @AlexisBRENON but this is a huge increase in complexity, with no description of why and no docs for how a chart user might make use of this feature.

@max-rocket-internet
Copy link
Member

How about a more generic approach that moves all this complexity to the values provided to the chart (and hence the person wanting to do this):

  • Add a .Values.initContainers option
  • Add a .Values.volumes option

This would be very simple and also, AFAIU, would allow you to achieve the same thing?

@AlexisBRENON
Copy link
Author

Thanks for the feedback. I agree, I didn't take time to document the new features, maybe I opened the PR a little bit early (moreover, the template is not rendering for the moment...).

Using a more generic approach report the complexity on the user of the chart. Moreover, it also requires a .Values.sidecars to allow for the git sync sidecar... Once documented, you will see that the use is quiet straight-forward, allowing the user to use any Git repository as the source of multiple locustfiles (as well as libraries, requirements file, etc.).
I tried to not break the current compatibility.

For information, I took inspiration from the Apache Airflow chart which can also relies on Git Sync to provide DAG files to the different components.

Are you totally againt such solution (in which case I can close the PR) or would you let me improve it a little bit (at least adding the documentation) (in which case I will ping you back when it's done) ? Or I can close the current PR and open a new one when I'm ready.

@max-rocket-internet
Copy link
Member

I'm on holiday right now, I'll revisit it when I get back in Jan, but in principle if there's a bunch of people that want this feature then all good, of course we can fix the issues and merge. But it looks like quite an advanced use case and from what I've seen so far, from the locust repo issues and the locust Slack org, even just using the helm chart as it is now can be a challenge.

If anyone else has strong opinions on this then feel free to chime in 😃

Happy holidays @AlexisBRENON 🎄

Copy link
Contributor

github-actions bot commented Jan 2, 2025

This PR is stale because it has been open 14 days with no activity. Remove stale label or comment or this will be closed in 5 days.

@AlexisBRENON
Copy link
Author

AlexisBRENON commented Jan 6, 2025

Hi.

I fixed the rendering issue and tried to add more documentation.

There is still some stuffs that I copied from the Airflow chart, without exactly knowing what it is used for (lifecycle hooks and security context). I could drop them if you want to keep the code more smaller, but I suspect that it may be of use for certain kind of deployment.

Finally, the refactor to allow different images between master and worker may be in another PR, what do you think ? But in this case, where should I put the git Sync image configuration (in gitSync.image or gitSyncImage?). I mainly did it to be consistent between master/worker/gitSync image configuration.

As said before, I tried to do a non-breaking change. So a working release should still work with the same values (the images are fetched from the old image object, the configmap is generated for locustfile).

Comment on lines +111 to +137
images:
# images.defaultLocustRepository -- default image used by locust containers (master and workers)
defaultLocustRepository: locustio/locust
# images.defaultLocustTag -- default tag used by locust containers (master and workers)
defaultLocustTag: 2.32.2

master:
# images.master.repository -- image used by locust master container
repository: ~
# images.master.tag -- tag used by locust master container
tag: ~
pullPolicy: IfNotPresent

worker:
# images.worker.repository -- image used by locust worker containers
repository: ~
# images.worker.tag -- tag used by locust worker containers
tag: ~
pullPolicy: IfNotPresent

gitSync:
# images.gitSync.repository -- image used by gitSync container
repository: registry.k8s.io/git-sync/git-sync
# images.gitSync.tag -- tag used by gitSync container
tag: v4.1.0
pullPolicy: IfNotPresent

Copy link
Member

Choose a reason for hiding this comment

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

Why do we need all this complexity about images? Is it related to git sync?

mountPath: "/mnt/locust"
# locustfiles.requirements -- Path to a file containing requirements to install
requirements: ~
gitSync:
Copy link
Member

Choose a reason for hiding this comment

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

I think you can simply remove a lot of they keys in here to make it simpler, e.g. containerName, uid, securityContext, securityContexts, containerLifecycleHooks, extraVolumeMounts etc.

Do we really need to set all these just to get git-sync working? I would say just leave all these as k8s defaults if not

@@ -45,11 +45,18 @@ spec:
{{- if .Values.hostAliases }}
hostAliases: {{- .Values.hostAliases | toYaml | nindent 8 }}
{{- end }}
initContainers:
{{- if .Values.locustfiles.gitSync.enabled }}
Copy link
Member

Choose a reason for hiding this comment

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

Does this not leave a key with no value if gitSync is not enabled?

@max-rocket-internet
Copy link
Member

It remains way too complicated IMO. I would say either make it much simpler or just create a separate chart, e.g. locust-gitsync. In this separate chart you can also remove loads of things, like the default configmaps etc.

@max-rocket-internet
Copy link
Member

Yeah now I think about it, let's do it as a separate chart and see how it evolves form there, how popular it is, how many contributions it gets etc 😃

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

Successfully merging this pull request may close these issues.

2 participants