VarnishCluster Configuration

Field Description Is Required
affinity Affinity settings for the pods. It allows you to configure onto which nodes Varnish pods should prefer being scheduled. optional
priorityClassName priorityClass settings for the pods. It allows you to set a PriorityClassName and thus set a priority to your pods, to avoid eviction. optional
backend.namespaces Namespace(s) to look for backend pods. By default - namespace the VarnishCluster is deployed to. required
backend.onlyReady Include (false, by default) or exclude (true) backend pods from the VCL (.Backends template var). Alters .Backends template variable based on Kubernetes health checks (by default not ready pods are also included in VCL) instead of Varnish health probes. optional
backend.port The port of the backend pods being cached by Varnish. Can be port name or port number. required
backend.selector The selector used to identify the backend Pods. required
backend.zoneBalancing Controls Varnish backend topology aware routing which can assign weights to backends according to their geographical location. optional
backend.zoneBalancing.type Varnish backend zone-balancing type. Accepted values: disabled, auto, thresholds optional
backend.zoneBalancing.thresholds Array of thresholds objects to determine condition and respective weights to be assigned to backends: threshold, local - local backend weight, remote - remote backend weight optional
logLevel The minimum enabled logging level. Allowed values: debug, info, warn, error, dpanic, panic, fatal. Default: info optional
logFormat Format of the logs. Can be json and console. Default: json optional
monitoring The operator monitoring configuration object optional
monitoring.grafanaDashboard A dashboard that can be installed along with the operator and used in grafana. Installed as a ConfigMap. optional
monitoring.grafanaDashboard.enabled Enable or disable the ConfigMap installation. Default: false optional
monitoring.grafanaDashboard.datasourceName Name of the Grafana datasource the dashboard should use. required
monitoring.grafanaDashboard.labels ConfigMap labels. Can be used to for discovery by grafana. See the .sidecar.dashboards.label config parameter of Grafana chart for more details. Default: { grafana_dashboard: "1" } optional
monitoring.grafanaDashboard.namespace Namespace that the ConfigMap with the dashboard should be installed to. Default to the namespace VarnishCluster is installed to optional
monitoring.grafanaDashboard.title Title of the Grafana dashboard. Default: Varnish (<cluster namespace>/<name>) optional
monitoring.prometheusServiceMonitor The Prometheus ServiceMonitor that is preconfigured to monitors the operator pods. optional
monitoring.prometheusServiceMonitor.enabled Enable or disable ServiceMontitor installation. Default: false optional
monitoring.prometheusServiceMonitor.labels ServiceMonitor labels that will be used by Prometheus instance to discover this ServiceMonitor. optional
monitoring.prometheusServiceMonitor.namespace The namespace the it should be installed to. Default to the namespace VarnishCluster is installed to optional
nodeSelector Node selector to control where the Varnish pods should be scheduled optional
podAnnotations Pod annotations for the Varnish pods. optional
podDisruptionBudget Pod Disruption Budget configuration. Can be used to tell Kubernetes how many pods are required to be up (or allowed to be down) to not cause service disruption optional
podDisruptionBudget.minAvailable An eviction is allowed if at least minAvailable pods will still be available after the eviction, i.e. even in the absence of the evicted pod optional
podDisruptionBudget.maxUnavailable An eviction is allowed if at most maxUnavailable pods are unavailable after the eviction, i.e. even in absence of the evicted pod. This is a mutually exclusive setting with minAvailable optional
replicas Number of Varnish nodes required
service Varnish service configuration. required
service.annotations Additional annotations for the service. optional
service.port The port number used to expose Varnish pods. required
service.metricsPort The port that will expose the Prometheus metrics exporter. Default: 9131. optional
service.nodePort The port number used to set NodePort for Varnish. Service type `NodePort should be selected. optional
service.metricsNodePort The port number used to set NodePort for Varnish Metrics Exporter. Service type `NodePort should be selected. optional
service.controllerMetricsNodePort The port number used to set NodePort for Varnish Controller Metrics exporter. Service type `NodePort should be selected. optional
service.type Type of the Service. Allowed values: ClusterIP; LoadBalancer; NodePort. optional
tolerations Configuration that defines which node taints can the pods tolerate. For example to allow Varnish pods to run on nodes that are marked (tainted) as machines dedicated for in-memory cache optional
updateStrategy Allows to control the way Varnish pods will be updated. optional
updateStrategy.type Defines the type of the update strategy. Default: OnDelete optional
updateStrategy.delayedRollingUpdate Configuration for DelayedRollingUpdate strategy optional
updateStrategy.delayedRollingUpdate.delaySeconds Indicates the wait time between pod reloads during rolling update. Default: 60 seconds required
updateStrategy.rollingUpdate Used to communicate parameters when type is RollingUpdate optional
updateStrategy.rollingUpdate.partition Partition indicates the ordinal at which the StatefulSet should be partitioned. Default: 0 optional
varnish An object that defines the configuration of a particular Varnish instance being deployed optional
varnish.admAuth An object that defines custom kubernetes secret to keep a Varnish authentication data to secure communication for varnishadm utility. Cluster creates its own if omitted. optional
varnish.admAuth.secretName The name of kubernetes secret which keeps auth data for varnishadm. required
varnish.admAuth.key The key from kubernetes secret which to use to collect data credentials for varnishadm. If the key is omitted, the cluster will use "secret" as the key. If the value associated to the key is empty, the cluster will generate a secret. optional
varnish.args Additional Varnish daemon arguments optional
varnish.controller An object that defines the configuration of a particular Varnish controller being deployed optional
varnish.controller.image Path to the Varnish Controller image being used. If not defined uses varnish.image+-controller suffix. Something like varnish-controller optional
varnish.controller.imagePullPolicy Image pull policy for the container. Default: Always optional
varnish.controller.resources Resource requests and limits for Varnish controller container. optional
varnish.envFrom Injects an env var into the Varnish container from a ConfigMap or Secret. Useful if a value needs to be passed (securely in case of Secret) to the VCL files. So it can be read using std.getenv(). optional
varnish.envFrom.configMapRef The ConfigMap to select from optional
varnish.envFrom.configMapRef.name Name of the ConfigMap optional
varnish.envFrom.configMapRef.optional Specify whether the ConfigMap must be defined optional
varnish.envFrom.prefix An optional identifier to prepend to each key. Must be a C_IDENTIFIER optional
varnish.envFrom.secretRef The Secret to select from optional
varnish.envFrom.secretRef.name Name of the Secret optional
varnish.envFrom.secretRef.optional Specify whether the Secret must be defined optional
varnish.extraInitContainers Additional init containers optional
varnish.extraVolumeClaimTemplates[] VolumeClaimTemplates for the VarnishCluster statefulset optional
varnish.extraVolumeClaimTemplates[].metadata Metadata for the VolumeClaimTemplate optional
varnish.extraVolumeClaimTemplates[].metadata.name Name of the volume optional
varnish.extraVolumeClaimTemplates[].metadata.labels Labels to set for the VolumeClaimTemplate optional
varnish.extraVolumeClaimTemplates[].metadata.annotations Annotations to set for the VolumeClaimTemplate optional
varnish.extraVolumeClaimTemplates[].spec Spec for the PersistentVolumeClaim optional
varnish.extraVolumeMounts Additional volume mounts for the Varnish container optional
varnish.extraVolumes Additional volumes optional
varnish.image Path to the Varnish image being used optional
varnish.imagePullPolicy Image pull policy for the Varnish container. Default: Always optional
varnish.imagePullSecret The name of the image pull secret to use to pull container images optional
varnish.metricsExporter An object that defines the configuration of a particular Varnish Prometheus metrics exporter being deployed optional
varnish.metricsExporter.image Path to the Varnish Metrics exporter image being used. If not defined uses varnish.image+-metrics-exporter suffix. Something like varnish-metrics-exporter optional
varnish.metricsExporter.imagePullPolicy Image pull policy for the container. Default: Always optional
varnish.metricsExporter.resources Resource requests and limits for Varnish metrics exporter container. optional
varnish.resources Resource requests and limits for Varnish container. optional
vcl An object that defines the VCL ConfigMap configuration required
vcl.configMapName Name of the ConfigMap containing the VCL configuration files required
vcl.entrypointFileName The name of the main VCL file required

You can also find an example of VarnishCluster with detailed comments here.

results matching ""

    No results matching ""