Chris Funderburg 8acf18a960 | 2 years ago | |
---|---|---|
.. | ||
templates | 2 years ago | |
.helmignore | 2 years ago | |
Chart.lock | 2 years ago | |
Chart.yaml | 2 years ago | |
README.md | 2 years ago | |
dev-values.yaml | 2 years ago | |
values.yaml | 2 years ago |
This is a Helm chart for installing Mastodon into a Kubernetes cluster. The basic usage is:
values.yaml
or create a separate yaml file for custom valueshelm dep update
helm install --namespace mastodon --create-namespace my-mastodon ./ -f path/to/additional/values.yaml
This chart is tested with k8s 1.21+ and helm 3.6.0+.
The variables that must be configured are:
password and keys in the mastodon.secrets
, postgresql
, and redis
groups; if
left blank, some of those values will be autogenerated, but will not persist
across upgrades.
SMTP settings for your mailer in the mastodon.smtp
group.
You can run admin CLI commands in the web deployment.
kubectl -n mastodon exec -it deployment/mastodon-web -- bash
tootctl accounts modify admin --reset-password
or
kubectl -n mastodon exec -it deployment/mastodon-web -- tootctl accounts modify admin --reset-password
Currently this chart does not support:
Because database migrations are managed as a Job separate from the Rails and Sidekiq deployments, it’s possible they will occur in the wrong order. After upgrading Mastodon versions, it may sometimes be necessary to manually delete the Rails and Sidekiq pods so that they are recreated against the latest migration.
The annotations previously defaulting to nginx have been removed and support for ingressClassName has been added.
ingress:
annotations:
kubernetes.io/ingress.class: nginx
kubernetes.io/tls-acme: "true"
To restore the old functionality simply add the above snippet to your values.yaml
,
but the recommendation is to replace these with ingress.ingressClassName
and use
cert-manager's issuer/cluster-issuer instead of tls-acme.
If you're uncertain about your current setup leave ingressClassName
empty and add
kubernetes.io/tls-acme
to ingress.annotations
in your values.yaml
.
Because of the changes in #19706 the upgrade may fail with the following error:
Error: UPGRADE FAILED: cannot patch "mastodon-sidekiq"
If you want an easy upgrade and you're comfortable with some downtime then simply delete the -sidekiq, -web, and -streaming Deployments manually.
If you require a no-downtime upgrade then:
helm template
instead of helm upgrade
services.yml
deployments.yml
deployments.yml
kubectl apply -f deployments.yml
then wait until all pods are readykubectl apply -f services.yml
helm upgrade
like normalkubectl delete -f deployments.yml
to clear out the temporary deploymentsIf you've previously installed the chart and you're having problems with
postgres not accepting your password then make sure to set username
to
postgres
and password
and postgresPassword
to the same passwords.
postgresql:
auth:
username: postgres
password: <same password>
postgresPassword: <same password>
And make sure to set password
to the same value as postgres-password
in your mastodon-postgresql
secret:
kubectl edit secret mastodon-postgresql