alfresco-repository

Version: 0.8.1 Type: application AppVersion: 23.4.0

Alfresco content repository Helm chart

Checkout alfresco-content-services chart’s doc for an example of how to leverage this chart from an umbrella chart.

Requirements

Repository Name Version
https://alfresco.github.io/alfresco-helm-charts/ alfresco-common 3.1.4
oci://registry-1.docker.io/bitnamicharts postgresql 12.5.6

Values

Key Type Default Description
affinity.podAntiAffinity.preferredDuringSchedulingIgnoredDuringExecution[0] object {"podAffinityTerm":{"labelSelector":{"matchExpressions":[{"key":"app.kubernetes.io/name","operator":"In","values":["{{ template \"alfresco-repository.name\" $ }}"]},{"key":"app.kubernetes.io/instance","operator":"In","values":["{{ $.Release.Name }}"]},{"key":"app.kubernetes.io/component","operator":"In","values":["{{ $.Chart.Name }}"]}]},"topologyKey":"topology.kubernetes.io/zone"},"weight":10} Prefer scheduling pods in different zones
affinity.podAntiAffinity.preferredDuringSchedulingIgnoredDuringExecution[1] object {"podAffinityTerm":{"labelSelector":{"matchExpressions":[{"key":"app.kubernetes.io/name","operator":"In","values":["{{ template \"alfresco-repository.name\" $ }}"]},{"key":"app.kubernetes.io/instance","operator":"In","values":["{{ $.Release.Name }}"]},{"key":"app.kubernetes.io/component","operator":"In","values":["{{ $.Chart.Name }}"]}]},"topologyKey":"kubernetes.io/hostname"},"weight":5} Prefer scheduling pods on different nodes
args list []  
autoscaling.behavior.scaleDown.policies list [{"periodSeconds":60,"type":"Pods","value":1}] list of available policies for scaling down scale down either by one pod or by destroying 25% of the pods (whichever is smaller)
autoscaling.behavior.scaleUp.policies list [{"periodSeconds":60,"type":"Percent","value":50},{"periodSeconds":60,"type":"Pods","value":2}] list of available policies for scaling up scale up either by one pod or by adding 50% more pods (whichever is bigger)
autoscaling.behavior.scaleUp.stabilizationWindowSeconds int 30  
autoscaling.enabled bool false Toggle repository autoscaling
autoscaling.maxReplicas int 3 maximum number of replicas to spin up within the replicatset
autoscaling.metrics list [{"resource":{"name":"cpu","target":{"averageUtilization":75,"type":"Utilization"}},"type":"Resource"}] a list of resource the HPA controller should monitor For more details check https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#support-for-resource-metrics
autoscaling.minReplicas int 1 minimum number of replicas to spin up within the replicatset
command list []  
configuration.db.driver string nil JDBC driver class of the driver if none is provided the it is guessed from the URL provided
configuration.db.existingConfigMap.keys.driver string "DATABASE_DRIVER" configmap key where to find the JDBC driver class to use. The configmap may leverage the alfresco-repository.db.cm named template to auto-generate it from the sole url parameter.
configuration.db.existingConfigMap.keys.url string "DATABASE_URL" configmap key where to find the URL of the database
configuration.db.existingConfigMap.name string nil  
configuration.db.existingSecret object {"keys":{"password":"DATABASE_PASSWORD","username":"DATABASE_USERNAME"},"name":null} Existing secret and their keys where to find the database username & password.
configuration.db.existingSecret.keys.password string "DATABASE_PASSWORD" Key within the secret holding the database password
configuration.db.existingSecret.keys.username string "DATABASE_USERNAME" Key within the secret holding the database username
configuration.db.existingSecret.name string nil Name of a pre-existing secret containing database credentials
configuration.db.password string nil Password to authentication to the repository database
configuration.db.url string nil JDBC url of the database This is a mandatory parameter
configuration.db.username string nil Username to authentication to the repository database
configuration.hz.port int 5701 Hazelcast listener port Only change it if you use a custom image where the port has been changed from default
configuration.imap object see below Basic IMAP capabilities config (limited to enabling/disabling). In order to pass more IMAP properties and configure the subsystem more deeply, please use value environment.CATALINA_OPTS or configuration.repository.existingConfiMap and check the available properties for this subsystem
configuration.imap.enabled bool false Enable/Disable Alfresco repository IMAP capabilities
configuration.imap.port int 1143 port to use to listen for IMAP clients
configuration.imap.protocol string "imap" Protocol to use to talk to IMAP clients (imap or imaps)
configuration.imap.service.annotations string nil Use annations to get custom behavior of the loadbalancer exposing the service
configuration.messageBroker.existingConfigMap.keys.url string "BROKER_URL" Key within the configmap holding the message broker URL. It MUST be a failover URL as per the spec below: https://activemq.apache.org/failover-transport-reference.html
configuration.messageBroker.existingConfigMap.name string nil Name of a pre-existing configmap containing the message broker URL
configuration.messageBroker.existingSecret.keys.password string "BROKER_PASSWORD" Key within the secret holding the message broker password
configuration.messageBroker.existingSecret.keys.username string "BROKER_USERNAME" Key within the secret holding the message broker username
configuration.messageBroker.existingSecret.name string nil Name of a pre-existing secret containing message broker credentials
configuration.messageBroker.password string nil Password to authenticate to the message broker
configuration.messageBroker.url string nil Message Broker URL
configuration.messageBroker.username string nil Username to authenticate to the message broker
configuration.repository.existingConfigMap string nil a configmap containing the “alfresco-global.properties” key populated with actual Alfresco repository properties see details
configuration.repository.existingSecrets list [{"key":"license.lic","name":"repository-secrets","purpose":"acs-license"}] A list of secrets to make available to the repository as env vars. This list can contain special secrets marked with predefined purpose: acs-license to pass license as a secret or subsystems:: to configure an Alfresco subsystem. See Configuring Alfresco Subsystem for more details.
configuration.search.existingConfigMap.keys.flavor string "SEARCH_FLAVOR" configmap key where to find the search engine used
configuration.search.existingConfigMap.keys.host string "SEARCH_HOST" configmap key where to find the hostname part of the search URL. The configmap may leverage the alfresco-repository.solr.cm named template to auto-generate it from the sole url parameter.
configuration.search.existingConfigMap.keys.port string "SEARCH_PORT" configmap key where to find the port part of the search URL. The configmap may leverage the alfresco-repository.solr.cm named template to auto-generate it from the sole url parameter.
configuration.search.existingConfigMap.keys.securecomms string "SEARCH_SECURECOMMS" configmap key where to find the search communication security type. The configmap may leverage the alfresco-repository.solr.cm named template to auto-generate it from the sole url parameter.
configuration.search.existingConfigMap.keys.solr_base_url string "SOLR_BASE_URL" configmap key where to find the root path to Solr. The configmap may leverage the alfresco-repository.solr.cm named template to auto-generate it from the sole url parameter. Not applicable to Elasticsearch
configuration.search.existingConfigMap.keys.url string "SEARCH_URL" Key within the configmap holding the search service URL.
configuration.search.existingConfigMap.name string nil Optional configmap containing the search service URL
configuration.search.existingSecret.keys.password string "ELASTICSEARCH_PASSWORD" Key within the secret holding the search service password
configuration.search.existingSecret.keys.solr-secret string "SOLR_SECRET" Key within the secret holding the index shared secret
configuration.search.existingSecret.keys.username string "ELASTICSEARCH_USERNAME" Key within the secret holding the search service username
configuration.search.existingSecret.name string nil Optional secret containing search service credentials
configuration.search.flavor string "noindex" Can be either solr, elasticsearch or noindex
configuration.search.password string nil Password to authenticate to the search service
configuration.search.solr-secret string nil Solr inter process shared secret
configuration.search.url string nil URL where the search service can be found
configuration.search.username string nil Username to authenticate to the search service
configuration.smtp object see below Basic SMTP capabilities config (limited to enabling/disabling). In order to pass more SMTP properties and configure the subsystem more deeply, please use value environment.CATALINA_OPTS or configuration.repository.existingConfigMap and check the available properties for this subsystem
configuration.smtp.enabled bool false Enable/Disable Alfresco repository SMTP capabilities
configuration.smtp.port int 1025 port to use to listen for SMTP clients
configuration.smtp.service.annotations string nil Use annations to get custom behavior of the loadbalancer exposing the service
environment.CATALINA_OPTS string nil Java or Tomcat system properties. These properties must be provided as a single string following the pattern “-Dproperty=value -Dmoreprop=morevalue”. They override the content of the global properties file but you should prefer providing configuration.repository.existingConfigMap.
environment.JAVA_OPTS string "-XX:MaxRAMPercentage=80" Set JVM options
extraInitContainers list []  
extraSideContainers list []  
extraVolumeMounts list []  
extraVolumes list []  
fullnameOverride string ""  
global.alfrescoRegistryPullSecrets string "quay-registry-secret" If a private image registry a secret can be defined and passed to kubernetes, see: https://github.com/Alfresco/acs-deployment/blob/a924ad6670911f64f1bba680682d266dd4ea27fb/docs/helm/eks-deployment.md#docker-registry-secret
global.known_urls string nil a fallback for .Values.known_urls that can be shared between charts
image.port int 8080  
image.pullPolicy string "IfNotPresent"  
image.repository string "quay.io/alfresco/alfresco-content-repository"  
image.tag string "23.4.0"  
imagePullSecrets list []  
ingress.annotations object {"nginx.ingress.kubernetes.io/affinity":"cookie","nginx.ingress.kubernetes.io/proxy-body-size":"5g","nginx.ingress.kubernetes.io/session-cookie-hash":"sha1","nginx.ingress.kubernetes.io/session-cookie-name":"alfrescoRepo"} provide annotations for nginx ingress (no toher ingress is supported at that point)
ingress.className string "nginx" supported ingress class
ingress.enabled bool true Toggle ingress
ingress.hosts[0].paths[0].path string "/"  
ingress.hosts[0].paths[0].pathType string "Prefix"  
ingress.hosts[0].paths[1].path string "/api-explorer"  
ingress.hosts[0].paths[1].pathType string "Prefix"  
ingress.tls list []  
initContainers.waitDbReady.image.pullPolicy string "IfNotPresent"  
initContainers.waitDbReady.image.repository string "busybox"  
initContainers.waitDbReady.image.tag string "1.37.0"  
initContainers.waitDbReady.resources.limits.cpu string "250m"  
initContainers.waitDbReady.resources.limits.memory string "20Mi"  
livenessProbe.httpGet.path string "/alfresco/api/-default-/public/alfresco/versions/1/probes/-live-"  
livenessProbe.httpGet.port string "http"  
livenessProbe.periodSeconds int 20  
livenessProbe.timeoutSeconds int 3  
nameOverride string ""  
nodeSelector object {}  
persistence.accessModes list ["ReadWriteMany"] Specify a storageClass for dynamic provisioning
persistence.baseSize string "20Gi"  
persistence.data.mountPath string "/usr/local/tomcat/alf_data"  
persistence.data.subPath string "alfresco-content-services/repository-data"  
persistence.enabled bool false Persist Contentsotre data
persistence.existingClaim string nil Use pre-provisioned pv through its claim (e.g. static provisioning)
persistence.storageClass string nil Bind PVC based on storageClass (e.g. dynamic provisioning)
podAnnotations object {}  
podSecurityContext.fsGroup int 1000  
podSecurityContext.runAsGroup int 1000  
podSecurityContext.runAsNonRoot bool true  
podSecurityContext.runAsUser int 33000  
readinessProbe.httpGet.path string "/alfresco/api/-default-/public/alfresco/versions/1/probes/-ready-"  
readinessProbe.httpGet.port string "http"  
readinessProbe.periodSeconds int 20  
readinessProbe.timeoutSeconds int 3  
replicaCount int 1  
resources.limits.cpu string "4"  
resources.limits.memory string "8Gi"  
resources.requests.cpu string "2"  
resources.requests.memory string "2Gi"  
securityContext object {}  
service.name string "repository"  
service.port int 80  
service.type string "ClusterIP"  
serviceAccount.annotations object {}  
serviceAccount.create bool true  
serviceAccount.name string "alfresco-repo-sa"  
startupProbe.failureThreshold int 9  
startupProbe.httpGet.path string "/alfresco/api/-default-/public/alfresco/versions/1/probes/-live-"  
startupProbe.httpGet.port string "http"  
startupProbe.periodSeconds int 20  
startupProbe.timeoutSeconds int 3  
strategy.rollingUpdate.maxSurge int 1  
strategy.rollingUpdate.maxUnavailable int 0  
strategy.type string "RollingUpdate"  
tags.ci bool false A chart tag used for Hyland’s CI purpose. Do not set it to true.
terminationGracePeriod int 60 How long to wait for tomcat to complete shutdown before killing it
tolerations list []