Any customisations (including major configuration changes) should be done inside the Docker image, resulting in the creation of a new image with a new tag. This approach allows changes to be tracked in the source code (Dockerfile) and rolling updates to the deployment in the K8s cluster.
The helm chart configuration customisation should only include environment-specific changes (for example DB server connection properties) or altered Docker image names and tags. The configuration changes applied via "--set" will only be reflected in the configuration stored in k8s cluster, a better approach would be to have those in source control i.e. maintain your own values files.
The docker compose Customisation Guide provides a detailed example of how to apply an AMP in a custom image and a more advanced example of building a custom image with configuration can be found here.
Once you have created your custom image you can either change the default values in the appropriate values file in this folder or you can override the values via the --set
command line option during install as shown below:
helm install alfresco/alfresco-content-services --set repository.image.repository="yourRegistry" --set repository.image.tag="yourTag" --set share.image.repository="yourRegistry" --set share.image.tag="yourTag"
If you create custom images you may well store them in your private registry meaning you need to use multiple sets of credentials.
To achieve this you can login and then create a generic secret using the --from-file
option, as shown below.
docker login docker.io
docker login quay.io
kubectl create secret generic my-registry-secrets --from-file=.dockerconfigjson=/your-home/.docker/config.json --type=kubernetes.io/dockerconfigjson -n alfresco
You can then provide the secret name via the --set
option as shown below:
helm install alfresco/alfresco-content-services --set global.alfrescoRegistryPullSecrets=my-registry-secrets ...