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

NOTICE: Helm chart rework + future deprecation of this chart. #129

Open
timetinytim opened this issue Feb 26, 2024 · 9 comments
Open

NOTICE: Helm chart rework + future deprecation of this chart. #129

timetinytim opened this issue Feb 26, 2024 · 9 comments

Comments

@timetinytim
Copy link
Contributor

timetinytim commented Feb 26, 2024

We have some big plans for our official Mastodon helm chart.

The way we've been developing and distributing the current helm chart has been less than ideal in a few different ways, and since there's been a shortage of time and people to work on making this chart better & address users' issues and suggestions, development of this particular chart has not always followed best practices or used consistent conventions. So as a result, we want to move this chart to a new home, clean up the bloat, and refactor it into a couple different charts to better suit different use cases.

Our overall goals for this are:

  • Host our helm charts from a git repo that has helm repo support (helm repo add ...).
  • Host multiple helm charts out of one github repo.
    • Initial idea is one chart which includes dependencies, and one standalone for those bringing their own.
    • Allows us to host other helm charts that we write/utilize in our own instances.
  • Refactor/simplify the chart itself to be less bloated, and be more consistent with best practices and conventions.

All of this means that we will need to create a new git repository to host this. The new home for these charts will be located here once they're ready: https://github.com/mastodon/helm-charts.

This also means that this chart will eventually be deprecated, but we have no intention of doing it right away. Now that we have more resources to devote to the helm charts, we be going through all the issues and PRs in this chart, and addressing/incorporating them wherever we can, which will all be carried forward into the new chart. And this chart will continue to be supported for a while after the new charts' release to give everyone time to transition. However, because of these plans, any PRs or suggestions that result in large or fundamental changes will have to be rejected for the time being until the new repo is up and ready to go.

Please feel free to comment with any concerns or questions you might have!

@timetinytim timetinytim pinned this issue Feb 26, 2024
@24367dfa
Copy link

Have you considered using the github container registry to release the helm chart?

@WyriHaximus
Copy link
Contributor

Excited to see this, installing Mastodon through TerraForm is a pain with the current setup.
Will the new chart be able to in-place update installs of this chart without any downtime?

@timetinytim
Copy link
Contributor Author

@24367dfa
We have! That's one thing the new repository will be able to do. The way the current repo is set up doesn't allow this.

@WyriHaximus
Ideally yes, but we will have to see. One of the issues with the current chart is a lack of naming consistency, both within the code and in the resources created, and we want to fix that as well. But I personally definitely want it to be easy to update in-place, as that's what I want to do with the official instances 🙂

@WyriHaximus
Copy link
Contributor

@timetinytim Well, you could fix that with a multi step upgrade process using multiple versions to do that seamlessly. Happy to help test that

@abbottmg
Copy link
Contributor

I have a couple things I've implemented in a wrapper chart for my instance, which may be beneficial to this new effort. I'll bring them up here since it looks like early days on the other repo:

  • I wrote a pair of templates that allows more flexibility with ingresses, with the particular aim of accepting a list of hosts, each with a list of paths, and customizing ingress config at each point in that tree. One template handles in-cluster endpoints (useful for matching mastodon's default nginx conf and adding additional subdomains for monitoring or anything else the k8s project may want to support directly) while the other handles external endpoints (namely my S3 provider). The two templates can be combined as a refactor pass if others want to use it
  • A basic deployment of statsd, prometheus, and grafana, along with a nice statsd mapping from an IPng blog post
  • Rather than maintaining separate charts for postgres and all the ancillary tools that benefit it (eg pgbouncer, patroni for HA), I evaluated and ended up using the CrunchyData postgres operator. It offers a full postgres stack of the below tools, with a well thought out CRD and--more importantly IMHO--all the intercompatibility work done for each supported major version of pg:
    • postgres
    • pgbouncer
    • patroni
    • pgbackrest
    • pgAdmin
    • monitoring via pgMonitor (including support for prometheus, grafana, alertmanager) and pgnodemx

The PGO is notable in that they actually prefer that downstream developers implement and maintain their own chart to configure the CRD, asking that you at least fork their example repo chart rather than rely on them to publish the chart. It's a strange choice, and the example chart has a pretty good values hierarchy and handles most cases well, but the choice does align with your desire to own the dependency charts. You could even fork the operator chart as well, but I think pinning particular commits within the CRD chart would be fine. Either way, this would provide access to really solid support and documentation for setting up a postgres stack with relatively little effort compared to implementing a similar stack.

@gjorando
Copy link

gjorando commented Aug 6, 2024

Soooo... Is there any update regarding the future Helm charts? There hasn't been any update since October '23, do you have a roadmap and/or need help?

@deefdragon
Copy link

With the release of 4.3, is there any chance of an update on this? The existing helm chart I use to deploy (the xdcm one) does not support separate custom images for web & streaming, meaning I'd need to migrate to this chart to get 4.3, and as previously mentioned, its a pain when using helm through TerraForm to install this RN.

@timetinytim
Copy link
Contributor Author

@gjorando @deefdragon Apologies for the delay in response!

This is still something I want to make happen, but as the only devops person working on a bunch of other projects here, I unfortunately haven't any time to give to this. Though putting up a roadmap is definitely a good call, and the first step I will do in trying to get the done sooner rather than later, as that will clarify exactly what needs to get done for other people to help if they want to.

@abbottmg, this is super helpful stuff, thank you for pointing this out. Regarding your third point specifically, I've used the PGO from crunchydata as well and it seemed to work pretty well for me also. Though @renchap recently made me aware of another option (https://cloudnative-pg.io/) that I want to look into, which seems like it might fit our use cases better, though that is pending an actual test run of its functionality in the field.

@tariqajyusuf
Copy link

tariqajyusuf commented Jan 8, 2025

I proposed a temporary fix for the mastodon chart to have it in the repo. I'd be happy to take a stab at this. I've done a decent amount of devops stuff and I was going to poke at this anyway as an excuse to get a better grasp at helm and terraform.

Based on the discussion above, I'm wondering if it makes sense to put forward "thin" deployments first that you can use with managed databases and caches and then slowly refactor in the other ones.

For the monitoring points, perhaps we can have a supplementing image that orchestrates things like what @abbottmg mentioned.

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

No branches or pull requests

7 participants