-
Notifications
You must be signed in to change notification settings - Fork 998
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
chore: overhaul chart #620
Conversation
Curious, what are the use-cases that may require stateless deployment of Dragonfly? Caching? |
Yep. Lets say you have a cache-heavy Grafana Loki stack. It heavily benefits from having a fast cache backend, but it will still work without it and is pretty fast about refilling it's cache as well. So it'd be a waste of resources (and money - when using a managed kubernetes provider, as you're paying per GB), to deploy Dragonfly in a stateful mode, if it's not really needed. Additionally, as PersistentVolume reattachments are not instant, as they have to be removed from the previous worker node first, you might lose precious time while waiting for the PersistentVolume become available, before the Dragonfly Pod can be started. Actually, I think, all of our memcache and redis instances are stateless. |
e06b255
to
6fe4df8
Compare
@@ -0,0 +1,6 @@ | |||
command: | |||
- /usr/local/bin/dragonfly |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what's the reason you separated stuff into lots of tiny files? :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For CI. I'm trying to prepare another PR right now, which will make use of helm/chart-testing-action. Helm's ct
iterates over the ci
subfolder of a chart and tries to provision the chart with each file. That's useful for testing different combinations :)
I do not have any comments so if you finished with this PR I can merge 😃 |
This PR is finished :) Also opened #622 for the CI testing of the chart. If you're feeling fancy today, then merge 622 first and re-trigger the checks on this one :D |
6fe4df8
to
c75736f
Compare
@tamcore https://github.com/dragonflydb/dragonfly/actions/runs/3801785982/jobs/6466627069#step:9:75 Also, is it the right place to have the CI as part of our C++ CI? it uses docker images, so what's the point of the CI? Maybe make it part of the release pipeline? or introduce a separate pipeline that is triggered only on helm changes and also runs on docker release? |
On mobile, so only briefly. The check fails, because Kubernetes doesn't recognize the Pod (v0.12.0 tag) as ready, as it's not able to execute the health/readyness check we've defined in the chart, as that script wasn't included in the container build. This will be fixed with the next Dragonfly release. We could temporarily update the install step, to null the probes to make the linter happy. But then this change should be reverted after the next Dragonfly release. As for the inclusion in the main ci workflow, that seemed to be the right place at this point. The C++ checks also run every time an unrelated file gets changed. This one at least skips everything, if no change is detected. |
c75736f
to
098cb21
Compare
I've nulled the probes. For now that's fine, as we're only validating that the chart outputs valid Kubernetes resources. At a later point, when potentially trying to include clustering in the chart, the probes might need to be included again. |
This should greatly improve readability of the chart itself - moved the `Pod` spec for both the `Deployment` and `StatefulSet` into a common template in `_pod.yaml` - replace a bunch of `if $value; print $value`-type blocks with `with $value; print .` - replaced `command.set` in `values.yaml` with `command` directly - this was broken anyways, as the chart wrongly referenced `command.cmd` for both `Deployment` and `StatefulSet` - populated contrib/charts/dragonfly/ci/ folder for development/CI purposes Signed-off-by: Philipp Born <[email protected]>
098cb21
to
987fef6
Compare
This should greatly improve readability of the chart itself, and make it easier to extend in the future
Pod
spec for both theDeployment
andStatefulSet
into a common template in_pod.yaml
if $value; print $value
-type blocks withwith $value; print .
command.set
invalues.yaml
withcommand
directlycommand.cmd
for bothDeployment
andStatefulSet
.values-test.yaml
for development/CI purposesTo make use of
.values-test.yaml
, just pass it to--values
. For example:For stateless provisioning (aka
Deployment
)For stateful deployment (aka
StatefulSet
)