Skip to content

Latest commit

 

History

History
742 lines (636 loc) · 77.3 KB

README.md

File metadata and controls

742 lines (636 loc) · 77.3 KB

Helm chart for Zabbix.

License Version: 6.1.2 Downloads

Zabbix is a mature and effortless enterprise-class open source monitoring solution for network monitoring and application monitoring of millions of metrics.

This Helm chart installs Zabbix in a Kubernetes cluster.

Prerequisites

  • Kubernetes cluster 1.10+
  • Helm 3.0+
  • Kubectl
  • PV provisioner support in the underlying infrastructure (optional).

Install the kubectl and helm requirements following the instructions in this tutorial.

Installation

Attention!!! Read the Breaking changes of this helm chart.

Access the Kubernetes cluster.

Add Helm repository:

helm repo add zabbix-community https://zabbix-community.github.io/helm-zabbix

Update the list helm charts available for installation. This is recommend prior to installation/upgrade:

helm repo update

Get all versions of helm chart:

helm search repo zabbix-community/zabbix -l

Set the helm chart version you want to use. Example:

export ZABBIX_CHART_VERSION='6.1.2'

Export default values of zabbix chart to $HOME/zabbix_values.yaml file:

helm show values zabbix-community/zabbix --version $ZABBIX_CHART_VERSION > $HOME/zabbix_values.yaml

Change the values according to the environment in the $HOME/zabbix_values.yaml file. The items of Configuration section can be set via --set flag in installation command or change the values according to the need of the environment in $HOME/zabbix_values.yaml file.

Test the installation/upgrade with the command:

helm upgrade --install zabbix zabbix-community/zabbix \
 --dependency-update \
 --create-namespace \
 --version $ZABBIX_CHART_VERSION \
 -f $HOME/zabbix_values.yaml -n monitoring --debug --dry-run

Install/upgrade Zabbix with the command:

helm upgrade --install zabbix zabbix-community/zabbix \
 --dependency-update \
 --create-namespace \
 --version $ZABBIX_CHART_VERSION \
 -f $HOME/zabbix_values.yaml -n monitoring --debug

See the installation example in kind cluster in this tutorial.

How to access Zabbix

Create port-forward for Zabbix:

kubectl port-forward service/zabbix-zabbix-web 8888:80 -n monitoring

Login to Zabbix:

Troubleshooting

See the pods:

kubectl get pods -n monitoring

See details for each pod:

kubectl describe pods/POD_NAME -n monitoring

See all containers in the pod:

kubectl get pods POD_NAME -n monitoring -o jsonpath='{.spec.containers[*].name}*'

See the logs for each container in the pod:

kubectl logs -f pods/POD_NAME -c CONTAINER_NAME -n monitoring

Access the container prompt.

kubectl exec -it pods/POD_NAME -c CONTAINER_NAME -n monitoring -- sh

See details of Zabbix services.

kubectl get svc -n monitoring
kubectl get pods --output=wide -n monitoring
kubectl describe services zabbix -n monitoring

Uninstallation

To uninstall/delete the zabbix deployment:

helm uninstall zabbix -n monitoring

Breaking changes of this helm chart

Version 6.1.0

  • Removing support for non-default Kubernetes features and Custom Resource objects: IngressRoute, Route, more info: #123
  • Removing support for karpenter due to the more generalistic approach: #121
  • Adding support to deploy any arbitrary manifests together with this Helm Chart by embedding them in the .Values.extraManifests list (#121)
  • From now on, the keys to use for a unifiedSecret to configure postgresql access globally for all relevant components that this Helm Chart deploys, can be configured in values.yaml
  • It is now possible to use a different Schema other than "public" in Postgresql database, when using an external database

Version 6.0.0

  • New implementation of native Zabbix Server High Availability (see Support of native Zabbix Server High Availability section)
  • No breaking changes in values.yaml, but nevertheless you might want to review your values.yaml's zabbixServer.zabbixServerHA section

Version 5.0.0

  • Will be using Postgresql 16.x and Zabbix 7.x.
  • Adjust in extraEnv to add support in environment variables from configmap and secret. More info: #93

Version 4.0.0

  • Will be used Postgresql 15.x and Zabbix 6.x.
  • Allow install zabbix-agent2 as deployment and sidecar container. More info: #20
  • This release changes parameter names in preparation for addressing these issues in the future and use camelCase pattern where is possible. More info: #18 and #21
    • db_access -> postgresAccess
    • db_access.use_unified_secret -> postgresAccess.useUnifiedSecret
    • db_access.unified_secret_name -> postgresAccess.unifiedSecretName
    • db_access.unified_secret_autocreate -> postgresAccess.unifiedSecretAutoCreate
    • db_access.db_server_host -> postgresAccess.host
    • db_access.db_server_port -> postgresAccess.port
    • db_access.postgres_user -> postgresAccess.user
    • db_access.postgres_password -> postgresAccess.password
    • db_access.postgres_db -> postgresAccess.database
    • db_access.postgres_password_secret -> postgresAccess.passwordSecret
    • db_access.postgres_password_secret_key -> postgresAccess.passwordSecretKey
    • ingressroute -> ingressRoute
    • postgresql.existing_claim_name -> postgresql.existingClaimName
    • postgresql.storage_size -> postgresql.storageSize
    • postgresql.storage_class -> postgresql.storageClass
    • zabbix_image_tag -> zabbixImageTag
    • zabbixagent -> zabbixAgent
    • zabbixproxy -> zabbixProxy
    • zabbixserver -> zabbixServer
    • zabbixserver.pod_anti_affinity -> zabbixServer.podAntiAffinity
    • zabbixserver.ha_nodes_autoclean -> zabbixServer.haNodesAutoClean
    • zabbixserver.ha_nodes_autoclean.delete_older_than_seconds -> zabbixServer.haNodesAutoClean.deleteOlderThanSeconds
    • zabbixweb -> zabbixWeb
    • zabbixweb.pod_anti_affinity -> zabbixWeb.podAntiAffinity
    • zabbixweb.saml_certs_secret_name -> zabbixWeb.samlCertsSecretName
    • zabbixwebservice -> zabbixWebService
    • zabbixwebservice.pod_anti_affinity -> zabbixWebService.podAntiAffinity
    • zabbixwebservice.ignore_url_cert_errors -> zabbixWebService.ignoreURLCertErrors

Version 3.0.0

  • Will be used Postgresql 14.x and Zabbix 6.x.
  • This version removes the possibility to specify database username/password per subsection in favor of specifying all of them centrally at one place.
  • Also, the names of the values have changed from upper to lowercase.
  • It is now possible to start the Zabbix Server pods with replicas of more than 1. HA functionality of Zabbix will automatically be enabled and it is made sure that the database schema publication will only happen once, and not by all of the Zabbix Server pods at the same time.
  • More info: cetic/helm-zabbix#54

Version 2.0.0

  • Will be used Postgresql 14.x and Zabbix 6.x.
  • This version implements a central way of managing database access credentials using a secret, which then will be respected by all the components installed by this chart: zabbixServer, zabbixWeb and postgresql.
  • The secret must contain a number of keys indicating DB host, DB name, user and password and can direct towards a database installed within this chart, or an external database.
  • The benefit of this is that now the database can respect the values in the central DB access secret and initialize accordingly.
  • Last but not least, the credential secret can be chosen to be auto-generated (password will be set to a random string) at chart installation, if postgresql.enabled is set to true. With this, an easy to use "out-of-the-box" installation with as little customizations as possible is possible, while still obtaining a good level of security.
  • More info: cetic/helm-zabbix#53

Version 1.0.0

Zabbix components

About the Zabbix version supported

  • This helm chart is compatible with non-LTS version of Zabbix, that include important changes and functionalities.
  • But by default this helm chart will install the latest LTS version (example: 6.0.x). See more info in Zabbix Life Cycle & Release Policy page
  • When you want use a non-LTS version (example: 6.4.x), you have to set this in values.yaml yourself.

Zabbix Server

Zabbix Server is the central process of Zabbix software.

The server performs the polling and trapping of data, it calculates triggers, sends notifications to users. It is the central component to which Zabbix agents and proxies report data on availability and integrity of systems. The server can itself remotely check networked services (such as web servers and mail servers) using simple service checks Official documentation.

Zabbix Server can be operated in a High Availability mode since version 6.0 which is automatically enabled by this Helm chart when setting the Zabbix Server component to run more than 1 replica. In this HA mode, all Zabbix Server instances periodically send a heartbeat to the Database server (just updating a timestamp in a table) as well as which of the nodes is the "active" one. In case the active node does not send a heartbeat within a certain time, any of the remaining ones automatically take over. It is every time possible to join new nodes to the HA cluster by just raising the amount of replicas of the Zabbix Server.

Zabbix Agent

zabbix-agent2 is supported in this helm chart.

Zabbix Agent is deployed on a monitoring target to actively monitor local resources and applications (hard drives, memory, processor statistics etc) Official documentation.

Zabbix Web (frontend)

Zabbix Web interface is a part of Zabbix software. It is used to manage resources under monitoring and view monitoring statistics Official documentation.

Zabbix Web Service

Zabbix Web Service is a process that is used for communication with external web services Official documentation.

Zabbix Proxy

This helm chart installs Zabbix Proxy with SQLite3 support

Zabbix Proxy is a process that may collect monitoring data from one or more monitored devices and send the information to the Zabbix Server, essentially working on behalf of the server. All collected data is buffered locally and then transferred to the Zabbix Server the proxy belongs to Official documentation.

PostgreSQL

A database is required for zabbix to work, in this helm chart we're using Postgresql.

We use plain postgresql database by default WITHOUT persistence. If you want persistence or would like to use TimescaleDB instead, check the comments in the values.yaml file.

Support of native Zabbix Server High Availability

Since version 6.0, Zabbix has his own implementation of High Availability, which is a simple approach to realize a Hot-Standby high availability setup with Zabbix Server. This feature applies only to Zabbix Server component, not Zabbix Proxy, Webdriver, Web Frontend or such. In a Zabbix monitoring environment, by design, there can only be one central active Zabbix Server taking over the responsibility of storing data into database, calculating triggers, sending alerts, evt. The native High Availability concept does not change that, it just implements a way to have additional Zabbix Server processes being "standby" and "jumping in" as soon as the active one does not report it's availability (updating a table in the database), anymore. As such, the Zabbix Server High Availability works well together (and somewhat requires, to be an entirely high available setup), an also high available database setup. High availability of Postgres Database is not covered by this Helm Chart, but can rather easily be achieved by using one of the well-known Postgresql database operators PGO and CNPG, which are supported to be used with this Helm Chart.

For the HA feature, which has not been designed for usage in Kubernetes, to work in K8S, there have been some challenges to overcome, primarily the fact that Zabbix Server doesn't allow to upgrade or to initialize database schema when running in HA mode enabled. Intention by Zabbix is to turn HA mode off, issue Major Release Upgrade, turn HA mode back on. This doesn't conclude with Kubernetes concepts. Beside of that, some additional circumstances led us to an implementation as follows:

  • added a portion in values.yaml generally switching "Zabbix Server HA" on or off. If turned off, the Zabbix Server deployment will always be started with 1 replica and without the ZBX_HANODENAME env variable. This is an easy-to-use setup with no additional job pods, but it's not possible to just scale up zabbix server pods from here
  • when .Values.zabbixServer.zabbixServerHA.enabled is set to true, a Kubernetes Job, marked as Helm post-install,post-upgrade hook, is being deployed together with a Role, Rolebinding and ServiceAccount, allowing this job pod to execute some changes via Kubernetes API. The job runs after each installation and upgrade process, scales down zabbix server pods if needed, manages db entries for active HA and non-HA server nodes being connected to the database, etc. Additionally, this job figures out whether a migration from a non-HA enabled setup to a HA-enabled one has been done, and handles necessary actions (scale down pods, delete entries in database) accordingly
  • the sidecar containers running together with the Zabbix Server pods have been updated not only to prevent starting Zabbix Server pods when database is not available, but also when the schema version of the database is not yet the correct one, adding an additional layer of preventing pods from crashing

Additionally, in order to make it possible to use Active checks and Active Zabbix Proxies with a Zabbix Server setup having High Availability enabled, a HA Labels sidecar has been introduced, continuously monitoring the Zabbix server pod for amount of running Zabbix server processes to figure out whether the Pod is being "active" or "standby" Zabbix Server node, and updating HA-related labels on the pod, accordingly.

The reason to implement it this way and not by probing the port number, which was my initial approach, is that probing the port of Zabbix Server will make it generate a message in the log, stating that a connection without a proper payload has been initiated towards the Zabbix Server. More info: #115

Thanks

About the new home of helm chart

  • The new home of the Zabbix helm chart is: https://github.com/zabbix-community/helm-zabbix. It is a fork from the cetic/helm-zabbix.
  • In this issue it was agreed with Sebastien Dupont that the repository would get a new home.
  • We are grateful to Cetic for making the infrastructure available on CircleCI to host the helm chart from the start. Now, the new versions will be hosted on Github.
  • We are very grateful to Alexandre Nuttinck and Amen Ayadi, who were the first developers of the helm chart and who worked at Cetic. Your dedication and effort made it possible to install Zabbix on a Kubernetes cluster.

License

Apache License 2.0

Configuration

The following tables lists the configurable parameters of the chart and their default values.

Key Type Default Description
affinity object {} Affinity configurations. Reference: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/
extraManifests list [] Extra arbitrary Kubernetes manifests to deploy within the release
global.commonLabels object {} Labels to apply to all resources.
global.imagePullSecrets list [] Reference to one or more secrets to be used when pulling images. For example: imagePullSecrets: - name: "image-pull-secret"
ingress.annotations object {} Ingress annotations
ingress.enabled bool false Enables Ingress
ingress.hosts list [{"host":"chart-example.local","paths":[{"path":"/","pathType":"ImplementationSpecific"}]}] Ingress hosts
ingress.pathType string "Prefix" pathType is only for k8s >= 1.1=
ingress.tls list [] Ingress TLS configuration
nodeSelector object {} nodeSelector configurations. Reference: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/
postgresAccess.database string "zabbix" Name of database
postgresAccess.host string "zabbix-postgresql" Address of database host - ignored if postgresql.enabled=true
postgresAccess.password string "zabbix" Password of database - ignored if passwordSecret is set
postgresAccess.port string "5432" Port of database host - ignored if postgresql.enabled=true
postgresAccess.schema string "" Schema of database. Can be left empty if unifiedSecretSchemaKey is not set. Only being used if external database is used (postgresql.enabled not set)
postgresAccess.unifiedSecretAutoCreate bool true automatically create secret if not already present (works only in combination with postgresql.enabled=true)
postgresAccess.unifiedSecretDBKey string "dbname" key of the unified postgres access secret where database name for the postgres db is found
postgresAccess.unifiedSecretHostKey string "host" key of the unified postgres access secret where host ip / dns name for the postgres db is found
postgresAccess.unifiedSecretName string "zabbixdb-pguser-zabbix" Name of one secret for unified configuration of PostgreSQL access
postgresAccess.unifiedSecretPasswordKey string "password" key of the unified postgres access secret where password for the postgres db is found
postgresAccess.unifiedSecretPortKey string "port" key of the unified postgres access secret where the port for the postgres db is found
postgresAccess.unifiedSecretSchemaKey string "" key of the unified postgres access secret where schema name for the postgres db is found. Can be left empty (defaults to "public", then). Only being used if external database is used (postgresql.enabled not set)
postgresAccess.unifiedSecretUserKey string "user" key of the unified postgres access secret where user name for the postgres db is found
postgresAccess.useUnifiedSecret bool true Whether to use the unified PostgreSQL access secret
postgresAccess.user string "zabbix" User of database
postgresql.containerAnnotations object {} Annotations to add to the containers
postgresql.containerLabels object {} Labels to add to the containers
postgresql.enabled bool true Create a database using Postgresql
postgresql.extraContainers list [] Additional containers to start within the postgresql pod
postgresql.extraEnv list [] Extra environment variables. A list of additional environment variables.
postgresql.extraInitContainers list [] Additional init containers to start within the postgresql pod
postgresql.extraPodSpecs object {} Additional specifications to the postgresql pod
postgresql.extraRuntimeParameters object {"max_connections":100} Extra Postgresql runtime parameters ("-c" options)
postgresql.extraVolumeMounts list [] Additional volumeMounts to the postgresql container
postgresql.extraVolumes list [] Additional volumes to make available to the postgresql pod
postgresql.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
postgresql.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
postgresql.image.repository string "postgres" Postgresql Docker image name: chose one of "postgres" or "timescale/timescaledb"
postgresql.image.tag int 16 Tag of Docker image of Postgresql server, choice "16" for postgres "2.17.2-pg16" for timescaledb (Zabbix supports TimescaleDB. More info: https://www.zabbix.com/documentation/7.0/en/manual/installation/requirements)
postgresql.livenessProbe object {} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
postgresql.persistence.enabled bool false Whether to enable persistent storage for the postgres container or not
postgresql.persistence.existingClaimName bool false Existing persistent volume claim name to be used to store postgres data
postgresql.persistence.storageSize string "5Gi" Size of the PVC to be automatically generated
postgresql.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
postgresql.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
postgresql.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
postgresql.service.annotations object {} Annotations for the zabbix-server service
postgresql.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
postgresql.service.port int 5432 Port of service in Kubernetes cluster
postgresql.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
postgresql.startupProbe object {} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
postgresql.statefulSetAnnotations object {} Annotations to add to the statefulset
postgresql.statefulSetLabels object {} Labels to add to the statefulset
rbac.additionalRulesForClusterRole list []
rbac.create bool true Specifies whether the RBAC resources should be created
securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
serviceAccount.annotations object {} Optional additional annotations to add to the Service Account.
serviceAccount.automountServiceAccountToken bool true Automount API credentials for a Service Account.
serviceAccount.create bool true Specifies whether a service account should be created.
serviceAccount.labels object {} Optional additional labels to add to the Service Account.
serviceAccount.name string "" The name of the service account to use. If not set and create is true, a name is generated using the fullname template.
tolerations list [] Tolerations configurations. Reference: https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/
zabbixAgent.ZBX_ACTIVE_ALLOW bool false This variable is boolean (true or false) and enables or disables feature of active checks
zabbixAgent.ZBX_DEBUGLEVEL int 3 The variable is used to specify debug level, from 0 to 5
zabbixAgent.ZBX_PASSIVE_ALLOW bool true This variable is boolean (true or false) and enables or disables feature of passive checks. By default, value is true
zabbixAgent.ZBX_SERVER_HOST string "0.0.0.0/0" Zabbix Server host
zabbixAgent.ZBX_SERVER_PORT int 10051 Zabbix Server port
zabbixAgent.ZBX_TIMEOUT int 4 The variable is used to specify timeout for processing checks. By default, value is 4.
zabbixAgent.containerAnnotations object {} Annotations to add to the containers
zabbixAgent.containerLabels object {} Labels to add to the containers
zabbixAgent.daemonSetAnnotations object {} Annotations to add to the daemonSet
zabbixAgent.daemonSetLabels object {} Labels to add to the daemonSet
zabbixAgent.deploymentLabels object {} Labels to add to the deployment
zabbixAgent.enabled bool true Enables use of Zabbix Agent
zabbixAgent.extraContainers list [] Additional containers to start within the Zabbix Agent pod
zabbixAgent.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/agent2/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixAgent.extraInitContainers list [] Additional init containers to start within the Zabbix Agent pod
zabbixAgent.extraPodSpecs object {} Additional specifications to the Zabbix Agent pod
zabbixAgent.extraVolumeMounts list [] Additional volumeMounts to the zabbix Agent container
zabbixAgent.extraVolumes list [] Additional volumes to make available to the Zabbix Agent pod
zabbixAgent.hostRootFsMount bool true If true, agent pods mounts host / at /host/root
zabbixAgent.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixAgent.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixAgent.image.repository string "zabbix/zabbix-agent2" Zabbix Agent Docker image name. Can use zabbix/zabbix-agent or zabbix/zabbix-agent2
zabbixAgent.image.tag string nil Zabbix Agent Docker image tag, if you want to override zabbixImageTag
zabbixAgent.livenessProbe object {"failureThreshold":3,"periodSeconds":10,"successThreshold":1,"tcpSocket":{"port":"zabbix-agent"},"timeoutSeconds":3} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixAgent.livenessProbe.tcpSocket.port string "zabbix-agent" Port number/alias name of the container
zabbixAgent.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixAgent.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixAgent.runAsDaemonSet bool false Enable this mode if you want to run zabbix-agent as daemonSet. The 'zabbixAgent.runAsSidecar' option must be false.
zabbixAgent.runAsSidecar bool true Its is a default mode. Zabbix-agent will run as sidecar in zabbix-server and zabbix-proxy pods. Disable this mode if you want to run zabbix-agent as daemonSet
zabbixAgent.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixAgent.service.annotations object {} Annotations for the zabbix-agent service
zabbixAgent.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixAgent.service.externalIPs list [] externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service. These IPs are not managed by Kubernetes.
zabbixAgent.service.loadBalancerClass string "" loadBalancerClass is the class of the load balancer implementation this Service belongs to. If specified, the value of this field must be a label-style identifier, with an optional prefix, e.g. "internal-vip" or "example.com/internal-vip". Unprefixed names are reserved for end-users. This field can only be set when the Service type is 'LoadBalancer'. If not set, the default load balancer implementation is used, today this is typically done through the cloud provider integration, but should apply for any default implementation. If set, it is assumed that a load balancer implementation is watching for Services with a matching class. Any default load balancer implementation (e.g. cloud providers) should ignore Services that set this field. This field can only be set when creating or updating a Service to type 'LoadBalancer'. Once set, it can not be changed. This field will be wiped when a service is updated to a non 'LoadBalancer' type.
zabbixAgent.service.loadBalancerIP string "" Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.
zabbixAgent.service.loadBalancerSourceRanges list [] If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.
zabbixAgent.service.nodePort int 31050 NodePort port to allocate on each node (only if service.type = NodePort or Loadbalancer)
zabbixAgent.service.port int 10050 Port of service in Kubernetes cluster
zabbixAgent.service.sessionAffinity string "None" Supports "ClientIP" and "None". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
zabbixAgent.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixAgent.startupProbe object {"failureThreshold":5,"initialDelaySeconds":15,"periodSeconds":5,"successThreshold":1,"tcpSocket":{"port":"zabbix-agent"},"timeoutSeconds":3} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixAgent.startupProbe.tcpSocket.port string "zabbix-agent" Port number/alias name of the container
zabbixBrowserMonitoring.customWebDriverURL string "" Custom WebDriver URL. If set, it overrides the default internal WebDriver service URL. Set zabbixBrowserMonitoring.webdriver.enabled to false when setting this.
zabbixBrowserMonitoring.enabled bool false Enable browser pollers
zabbixBrowserMonitoring.pollers int 1 Number of browser pollers to start
zabbixBrowserMonitoring.webdriver.enabled bool true Enable webdriver
zabbixBrowserMonitoring.webdriver.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixBrowserMonitoring.webdriver.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixBrowserMonitoring.webdriver.image.repository string "selenium/standalone-chrome" WebDriver container image
zabbixBrowserMonitoring.webdriver.image.tag string "127.0-chromedriver-127.0-grid-4.23.0-20240727" WebDriver container image tag, See https://hub.docker.com/r/selenium/standalone-chrome/tags
zabbixBrowserMonitoring.webdriver.name string "chrome" WebDriver container name
zabbixBrowserMonitoring.webdriver.port int 4444 WebDriver container port
zabbixImageTag string "ubuntu-7.0.6" Zabbix components (server, agent, web frontend, ...) image tag to use. This helm chart is compatible with non-LTS version of Zabbix, that include important changes and functionalities. But by default this helm chart will install the latest LTS version (example: 7.0.x). See more info in Zabbix Life Cycle & Release Policy page When you want use a non-LTS version (example: 7.2.x), you have to set this yourself. You can change version here or overwrite in each component (example: zabbixserver.image.tag, etc).
zabbixJavaGateway.ZBX_DEBUGLEVEL int 3 The variable is used to specify debug level, from 0 to 5
zabbixJavaGateway.ZBX_JAVAGATEWAY string "zabbix-java-gateway" Additional arguments for Zabbix Java Gateway. Useful to enable additional libraries and features. ZABBIX_OPTIONS: Java Gateway Service Name
zabbixJavaGateway.ZBX_START_POLLERS int 5 This variable is specified amount of pollers. By default, value is 5
zabbixJavaGateway.ZBX_TIMEOUT int 3 This variable is used to specify timeout for outgoing connections. By default, value is 3.
zabbixJavaGateway.containerAnnotations object {} Annotations to add to the containers
zabbixJavaGateway.containerLabels object {} Labels to add to the containers
zabbixJavaGateway.deploymentAnnotations object {} Annotations to add to the deployment
zabbixJavaGateway.deploymentLabels object {} Labels to add to the deployment
zabbixJavaGateway.enabled bool false Enables use of Zabbix Java Gateway
zabbixJavaGateway.extraContainers list [] Additional containers to start within the Zabbix Java Gateway pod
zabbixJavaGateway.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/agent2/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixJavaGateway.extraInitContainers list [] Additional init containers to start within the Zabbix Java Gateway pod
zabbixJavaGateway.extraPodSpecs object {} Additional specifications to the Zabbix Java Gateway pod
zabbixJavaGateway.extraVolumeMounts list [] Additional volumeMounts to the Zabbix Java Gateway container
zabbixJavaGateway.extraVolumes list [] Additional volumes to make available to the Zabbix Java Gateway pod
zabbixJavaGateway.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixJavaGateway.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixJavaGateway.image.repository string "zabbix/zabbix-java-gateway" Zabbix Java Gateway Docker image name.
zabbixJavaGateway.image.tag string nil Zabbix Java Gateway Docker image tag, if you want to override zabbixImageTag
zabbixJavaGateway.livenessProbe object {"failureThreshold":3,"periodSeconds":10,"successThreshold":1,"tcpSocket":{"port":"zabbix-java-gw"},"timeoutSeconds":3} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixJavaGateway.livenessProbe.tcpSocket.port string "zabbix-java-gw" Port number/alias name of the container
zabbixJavaGateway.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixJavaGateway.replicaCount int 1 Number of replicas of Zabbix Java Gateway module
zabbixJavaGateway.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixJavaGateway.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixJavaGateway.service.annotations object {} Annotations for the zabbix-java-gateway service
zabbixJavaGateway.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixJavaGateway.service.externalIPs list [] externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service. These IPs are not managed by Kubernetes.
zabbixJavaGateway.service.loadBalancerClass string "" loadBalancerClass is the class of the load balancer implementation this Service belongs to. If specified, the value of this field must be a label-style identifier, with an optional prefix, e.g. "internal-vip" or "example.com/internal-vip". Unprefixed names are reserved for end-users. This field can only be set when the Service type is 'LoadBalancer'. If not set, the default load balancer implementation is used, today this is typically done through the cloud provider integration, but should apply for any default implementation. If set, it is assumed that a load balancer implementation is watching for Services with a matching class. Any default load balancer implementation (e.g. cloud providers) should ignore Services that set this field. This field can only be set when creating or updating a Service to type 'LoadBalancer'. Once set, it can not be changed. This field will be wiped when a service is updated to a non 'LoadBalancer' type.
zabbixJavaGateway.service.loadBalancerIP string "" Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.
zabbixJavaGateway.service.loadBalancerSourceRanges list [] If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.
zabbixJavaGateway.service.nodePort int 31052 NodePort port to allocate on each node (only if service.type = NodePort or Loadbalancer)
zabbixJavaGateway.service.port int 10052 Port of service in Kubernetes cluster
zabbixJavaGateway.service.sessionAffinity string "None" Supports "ClientIP" and "None". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
zabbixJavaGateway.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixJavaGateway.startupProbe object {"failureThreshold":5,"initialDelaySeconds":15,"periodSeconds":5,"successThreshold":1,"tcpSocket":{"port":"zabbix-java-gw"},"timeoutSeconds":3} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixJavaGateway.startupProbe.tcpSocket.port string "zabbix-java-gw" Port number/alias name of the container
zabbixProxy.ZBX_DEBUGLEVEL int 4
zabbixProxy.ZBX_HOSTNAME string "zabbix-proxy" Zabbix Proxy hostname Case sensitive hostname
zabbixProxy.ZBX_JAVAGATEWAY_ENABLE bool false The variable enable communication with Zabbix Java Gateway to collect Java related checks. By default, value is false.
zabbixProxy.ZBX_PROXYMODE int 0 The variable allows to switch Zabbix Proxy mode. By default, value is 0 - active proxy. Allowed values are 0 and 1.
zabbixProxy.ZBX_SERVER_HOST string "zabbix-zabbix-server" Zabbix Server host
zabbixProxy.ZBX_SERVER_PORT int 10051 Zabbix Server port
zabbixProxy.ZBX_TIMEOUT int 4
zabbixProxy.ZBX_VMWARECACHESIZE string "128M" Cache size
zabbixProxy.containerAnnotations object {} Annotations to add to the containers
zabbixProxy.containerLabels object {} Labels to add to the containers
zabbixProxy.enabled bool false Enables use of Zabbix Proxy
zabbixProxy.extraContainers list [] Additional containers to start within the Zabbix Proxy pod
zabbixProxy.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/proxy-sqlite3/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixProxy.extraInitContainers list [] Additional init containers to start within the Zabbix Proxy pod
zabbixProxy.extraPodSpecs object {} Additional specifications to the Zabbix Proxy pod
zabbixProxy.extraVolumeClaimTemplate list [] Extra volumeClaimTemplate for zabbixProxy statefulset
zabbixProxy.extraVolumeMounts list [] Additional volumeMounts to the Zabbix Proxy container
zabbixProxy.extraVolumes list [] Additional volumes to make available to the Zabbix Proxy pod
zabbixProxy.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixProxy.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixProxy.image.repository string "zabbix/zabbix-proxy-sqlite3" Zabbix Proxy Docker image name
zabbixProxy.image.tag string nil Zabbix Proxy Docker image tag, if you want to override zabbixImageTag
zabbixProxy.livenessProbe object {} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixProxy.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixProxy.replicaCount int 1 Number of replicas of zabbixProxy module
zabbixProxy.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixProxy.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixProxy.service.annotations object {} Annotations for the zabbix-proxy service
zabbixProxy.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixProxy.service.externalIPs list [] externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service. These IPs are not managed by Kubernetes.
zabbixProxy.service.loadBalancerClass string "" loadBalancerClass is the class of the load balancer implementation this Service belongs to. If specified, the value of this field must be a label-style identifier, with an optional prefix, e.g. "internal-vip" or "example.com/internal-vip". Unprefixed names are reserved for end-users. This field can only be set when the Service type is 'LoadBalancer'. If not set, the default load balancer implementation is used, today this is typically done through the cloud provider integration, but should apply for any default implementation. If set, it is assumed that a load balancer implementation is watching for Services with a matching class. Any default load balancer implementation (e.g. cloud providers) should ignore Services that set this field. This field can only be set when creating or updating a Service to type 'LoadBalancer'. Once set, it can not be changed. This field will be wiped when a service is updated to a non 'LoadBalancer' type.
zabbixProxy.service.loadBalancerIP string "" Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.
zabbixProxy.service.loadBalancerSourceRanges list [] If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.
zabbixProxy.service.nodePort int 31053 NodePort port to allocate on each node (only if service.type = NodePort or Loadbalancer)
zabbixProxy.service.port int 10051 Port of service in Kubernetes cluster
zabbixProxy.service.sessionAffinity string "None" Supports "ClientIP" and "None". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
zabbixProxy.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixProxy.startupProbe object {} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixProxy.statefulSetAnnotations object {} Annotations to add to the statefulset
zabbixProxy.statefulSetLabels object {} Labels to add to the statefulset
zabbixServer.containerAnnotations object {} Annotations to add to the containers
zabbixServer.containerLabels object {} Labels to add to the containers
zabbixServer.deploymentAnnotations object {} Annotations to add to the deployment
zabbixServer.deploymentLabels object {} Labels to add to the deployment
zabbixServer.enabled bool true Enables use of Zabbix Server
zabbixServer.extraContainers list [] Additional containers to start within the Zabbix Server pod
zabbixServer.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/server-pgsql/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixServer.extraInitContainers list [] Additional init containers to start within the Zabbix Server pod
zabbixServer.extraPodSpecs object {} Additional specifications to the Zabbix Server pod
zabbixServer.extraVolumeMounts list [] Additional volumeMounts to the Zabbix Server container
zabbixServer.extraVolumes list [] Additional volumes to make available to the Zabbix Server pod
zabbixServer.haNodesAutoClean object {"concurrencyPolicy":"Replace","cronjobLabels":{},"deleteOlderThanSeconds":3600,"enabled":true,"extraContainers":[],"extraEnv":[],"extraInitContainers":[],"extraPodSpecs":{},"extraVolumeMounts":[],"extraVolumes":[],"image":{"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"postgres","tag":16},"resources":{},"schedule":"0 1 * * *","securityContext":{}} Automatically clean orphaned ha nodes from ha_nodes db table
zabbixServer.haNodesAutoClean.cronjobLabels object {} Labels to add to the cronjob for ha nodes autoclean
zabbixServer.haNodesAutoClean.extraContainers list [] Additional containers to start within the cronjob hanodes autoclean
zabbixServer.haNodesAutoClean.extraEnv list [] Extra environment variables. A list of additional environment variables.
zabbixServer.haNodesAutoClean.extraInitContainers list [] Additional init containers to start within the cronjob hanodes autoclean
zabbixServer.haNodesAutoClean.extraPodSpecs object {} Additional specifications to the cronjob hanodes autoclean
zabbixServer.haNodesAutoClean.extraVolumeMounts list [] Additional volumeMounts to the cronjob hanodes autoclean
zabbixServer.haNodesAutoClean.extraVolumes list [] Additional volumes to make available to the cronjob hanodes autoclean
zabbixServer.haNodesAutoClean.image.repository string "postgres" Postgresql Docker image name: chose one of "postgres" or "timescale/timescaledb"
zabbixServer.haNodesAutoClean.image.tag int 16 Tag of Docker image of Postgresql server, choice "16" for postgres "2.17.2-pg16" for timescaledb (Zabbix supports TimescaleDB. More info: https://www.zabbix.com/documentation/7.0/en/manual/installation/requirements)
zabbixServer.haNodesAutoClean.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixServer.haNodesAutoClean.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixServer.hostIP string "0.0.0.0" Optional set hostIP different from 0.0.0.0 to open port only on this IP
zabbixServer.hostPort bool false Optional set true open a port direct on node where Zabbix Server runs
zabbixServer.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixServer.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixServer.image.repository string "zabbix/zabbix-server-pgsql" Zabbix Server Docker image name
zabbixServer.image.tag string nil Zabbix Server Docker image tag, if you want to override zabbixImageTag
zabbixServer.livenessProbe object {} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixServer.podAntiAffinity bool true Set permissive podAntiAffinity to spread replicas over cluster nodes if replicaCount>1
zabbixServer.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixServer.replicaCount int 1 Number of replicas of zabbixServer module
zabbixServer.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixServer.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixServer.service.annotations object {} Annotations for the zabbix-server service
zabbixServer.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixServer.service.externalIPs list [] externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service. These IPs are not managed by Kubernetes.
zabbixServer.service.loadBalancerClass string "" loadBalancerClass is the class of the load balancer implementation this Service belongs to. If specified, the value of this field must be a label-style identifier, with an optional prefix, e.g. "internal-vip" or "example.com/internal-vip". Unprefixed names are reserved for end-users. This field can only be set when the Service type is 'LoadBalancer'. If not set, the default load balancer implementation is used, today this is typically done through the cloud provider integration, but should apply for any default implementation. If set, it is assumed that a load balancer implementation is watching for Services with a matching class. Any default load balancer implementation (e.g. cloud providers) should ignore Services that set this field. This field can only be set when creating or updating a Service to type 'LoadBalancer'. Once set, it can not be changed. This field will be wiped when a service is updated to a non 'LoadBalancer' type.
zabbixServer.service.loadBalancerIP string "" Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.
zabbixServer.service.loadBalancerSourceRanges list [] If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.
zabbixServer.service.nodePort int 31051 NodePort port to allocate on each node (only if service.type = NodePort or Loadbalancer)
zabbixServer.service.port int 10051 Port of service in Kubernetes cluster
zabbixServer.service.sessionAffinity string "None" Supports "ClientIP" and "None". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
zabbixServer.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixServer.startupProbe object {} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixServer.zabbixServerHA object {"dbCreateUpgradeJob":{"extraContainers":[],"extraInitContainers":[],"extraPodSpecs":{},"extraVolumeMounts":[],"extraVolumes":[],"image":{"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-create-upgrade-db","tag":""},"resources":{},"securityContext":{}},"enabled":true,"haLabelsSidecar":{"extraVolumeMounts":[],"image":{"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-ha-label-manager","tag":"latest"},"labelName":"zabbix.com/server-ha-role","resources":{},"securityContext":{}},"role":{"annotations":{}},"roleBinding":{"annotations":{}},"serviceAccount":{"annotations":{}}} Section responsible for native Zabbix Server High Availability support of this Helm Chart
zabbixServer.zabbixServerHA.dbCreateUpgradeJob object {"extraContainers":[],"extraInitContainers":[],"extraPodSpecs":{},"extraVolumeMounts":[],"extraVolumes":[],"image":{"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-create-upgrade-db","tag":""},"resources":{},"securityContext":{}} Settings for the database initialization / upgrade job needed for HA enabled setups
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.extraContainers list [] Additional containers to start within the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.extraInitContainers list [] Additional init containers to start within the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.extraPodSpecs object {} Additional specifications to the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.extraVolumeMounts list [] Additional volumeMounts to the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.extraVolumes list [] Additional volumes to make available to the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.image object {"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-create-upgrade-db","tag":""} Image settings for the database initialization / upgrade job
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.image.pullPolicy string "IfNotPresent" Pull policy for the db initialization / upgrade job
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.image.pullSecrets list [] Pull secrets for the db initialization / upgrade job
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.image.repository string "registry.inqbeo.de/zabbix-dev/zabbix-server-create-upgrade-db" Image repository for the database initialization / upgrade job
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.image.tag string "" it is going to be chosen based of the zabbix_server pod container otherwise
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.resources object {} Resource requests and limits for the dbCreateUpgradeJob pod
zabbixServer.zabbixServerHA.dbCreateUpgradeJob.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixServer.zabbixServerHA.enabled bool true Enables Helm Chart support for Zabbix Server HA. If disabled, replicaCount will always be 1
zabbixServer.zabbixServerHA.haLabelsSidecar object {"extraVolumeMounts":[],"image":{"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-ha-label-manager","tag":"latest"},"labelName":"zabbix.com/server-ha-role","resources":{},"securityContext":{}} The HA labels sidecar checks for the current pod whether it is the active Zabbix Server HA node and sets labels on it, accordingly
zabbixServer.zabbixServerHA.haLabelsSidecar.extraVolumeMounts list [] Extra VolumeMounts for the HA labels sidecar
zabbixServer.zabbixServerHA.haLabelsSidecar.image object {"pullPolicy":"IfNotPresent","pullSecrets":[],"repository":"registry.inqbeo.de/zabbix-dev/zabbix-server-ha-label-manager","tag":"latest"} Image settings for the HA labels sidecar
zabbixServer.zabbixServerHA.haLabelsSidecar.image.pullPolicy string "IfNotPresent" Pull policy for the HA labels sidecar image
zabbixServer.zabbixServerHA.haLabelsSidecar.image.pullSecrets list [] Pull secrets for the HA labels sidecar image
zabbixServer.zabbixServerHA.haLabelsSidecar.image.repository string "registry.inqbeo.de/zabbix-dev/zabbix-server-ha-label-manager" Repository where to get the image for the HA labels sidecar container
zabbixServer.zabbixServerHA.haLabelsSidecar.image.tag string "latest" Tag of the HA labels sidecar container image
zabbixServer.zabbixServerHA.haLabelsSidecar.labelName string "zabbix.com/server-ha-role" Label name for the sidecar to set on the zabbix server pods, will be used in the zabbix server Service as an additional selector to point to the active Zabbix Server pod
zabbixServer.zabbixServerHA.haLabelsSidecar.resources object {} Resource requests and limits for the HA labels sidecar
zabbixServer.zabbixServerHA.haLabelsSidecar.securityContext object {} Security context for the HA labels sidecar
zabbixServer.zabbixServerHA.role object {"annotations":{}} K8S Role being used for database initialization and upgrade job, which needs access to certain Kubernetes resources
zabbixServer.zabbixServerHA.role.annotations object {} Extra annotations for the role needed to give the HA related sidecars and the DB job API permissions
zabbixServer.zabbixServerHA.roleBinding object {"annotations":{}} Rolebinding being used for the database initialization and upgrade job
zabbixServer.zabbixServerHA.roleBinding.annotations object {} Extra annotations for the roleBinding needed to give the HA related DB init and upgrade job
zabbixServer.zabbixServerHA.serviceAccount object {"annotations":{}} Serviceaccount for the database initialization and upgrade job
zabbixServer.zabbixServerHA.serviceAccount.annotations object {} Extra annotations for the serviceAccount needed to give the DB job API permissions
zabbixWeb.containerAnnotations object {} Annotations to add to the containers
zabbixWeb.containerLabels object {} Labels to add to the containers
zabbixWeb.deploymentAnnotations object {} Annotations to add to the deployment
zabbixWeb.deploymentLabels object {} Labels to add to the deployment
zabbixWeb.enabled bool true Enables use of Zabbix Web
zabbixWeb.extraContainers list [] Additional containers to start within the Zabbix Web pod
zabbixWeb.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/web-apache-pgsql/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixWeb.extraInitContainers list [] Additional init containers to start within the Zabbix Web pod
zabbixWeb.extraPodSpecs object {} Additional specifications to the Zabbix Web pod
zabbixWeb.extraVolumeMounts list [] Additional volumeMounts to the Zabbix Web container
zabbixWeb.extraVolumes list [] Additional volumes to make available to the Zabbix Web pod
zabbixWeb.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixWeb.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixWeb.image.repository string "zabbix/zabbix-web-nginx-pgsql" Zabbix Web Docker image name
zabbixWeb.image.tag string nil Zabbix Web Docker image tag, if you want to override zabbixImageTag
zabbixWeb.livenessProbe.failureThreshold int 6
zabbixWeb.livenessProbe.httpGet.path string "/" Path of health check of application
zabbixWeb.livenessProbe.httpGet.port string "zabbix-web" Port number/alias name of the container
zabbixWeb.livenessProbe.initialDelaySeconds int 30
zabbixWeb.livenessProbe.periodSeconds int 10
zabbixWeb.livenessProbe.successThreshold int 1
zabbixWeb.livenessProbe.timeoutSeconds int 5
zabbixWeb.podAntiAffinity bool true set permissive podAntiAffinity to spread replicas over cluster nodes if replicaCount>1
zabbixWeb.readinessProbe.failureThreshold int 6
zabbixWeb.readinessProbe.httpGet.path string "/" Path of health check of application
zabbixWeb.readinessProbe.httpGet.port string "zabbix-web" Port number/alias name of the container
zabbixWeb.readinessProbe.initialDelaySeconds int 5
zabbixWeb.readinessProbe.periodSeconds int 10
zabbixWeb.readinessProbe.successThreshold int 1
zabbixWeb.readinessProbe.timeoutSeconds int 5
zabbixWeb.replicaCount int 1 Number of replicas of zabbixWeb module
zabbixWeb.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixWeb.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixWeb.service object {"annotations":{},"clusterIP":null,"externalIPs":[],"loadBalancerClass":"","loadBalancerIP":"","loadBalancerSourceRanges":[],"nodePort":31080,"port":80,"sessionAffinity":"None","type":"ClusterIP"} Certificate containing certificates for SAML configuration samlCertsSecretName: zabbix-web-samlcerts
zabbixWeb.service.annotations object {} Annotations for the Zabbix Web
zabbixWeb.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixWeb.service.externalIPs list [] externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service. These IPs are not managed by Kubernetes.
zabbixWeb.service.loadBalancerClass string "" loadBalancerClass is the class of the load balancer implementation this Service belongs to. If specified, the value of this field must be a label-style identifier, with an optional prefix, e.g. "internal-vip" or "example.com/internal-vip". Unprefixed names are reserved for end-users. This field can only be set when the Service type is 'LoadBalancer'. If not set, the default load balancer implementation is used, today this is typically done through the cloud provider integration, but should apply for any default implementation. If set, it is assumed that a load balancer implementation is watching for Services with a matching class. Any default load balancer implementation (e.g. cloud providers) should ignore Services that set this field. This field can only be set when creating or updating a Service to type 'LoadBalancer'. Once set, it can not be changed. This field will be wiped when a service is updated to a non 'LoadBalancer' type.
zabbixWeb.service.loadBalancerIP string "" Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.
zabbixWeb.service.loadBalancerSourceRanges list [] If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.
zabbixWeb.service.nodePort int 31080 NodePort port to allocate on each node (only if service.type = NodePort or Loadbalancer)
zabbixWeb.service.sessionAffinity string "None" Supports "ClientIP" and "None". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
zabbixWeb.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixWeb.startupProbe object {} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixWebService.containerAnnotations object {} Annotations to add to the containers
zabbixWebService.containerLabels object {} Labels to add to the containers
zabbixWebService.deploymentAnnotations object {} Annotations to add to the deployment
zabbixWebService.deploymentLabels object {} Labels to add to the deployment
zabbixWebService.enabled bool true Enables use of Zabbix Web Service
zabbixWebService.extraContainers list [] Additional containers to start within the Zabbix Web Service pod
zabbixWebService.extraEnv list [] Extra environment variables. A list of additional environment variables. List can be extended with other environment variables listed here: https://github.com/zabbix/zabbix-docker/tree/6.0/Dockerfiles/web-service/alpine#environment-variables. See example: https://github.com/zabbix-community/helm-zabbix/blob/main/charts/zabbix/docs/example/kind/values.yaml
zabbixWebService.extraInitContainers list [] Additional init containers to start within the Zabbix Web Service pod
zabbixWebService.extraPodSpecs object {} Additional specifications to the Zabbix Web Service pod
zabbixWebService.extraVolumeMounts list [] Additional volumeMounts to the Zabbix Web Service container
zabbixWebService.extraVolumes list [] Additional volumes to make available to the Zabbix Web Service pod
zabbixWebService.image.pullPolicy string "IfNotPresent" Pull policy of Docker image
zabbixWebService.image.pullSecrets list [] List of dockerconfig secrets names to use when pulling images
zabbixWebService.image.repository string "zabbix/zabbix-web-service" Zabbix Webservice Docker image name
zabbixWebService.image.tag string nil Zabbix Webservice Docker image tag, if you want to override zabbixImageTag
zabbixWebService.livenessProbe object {} The kubelet uses liveness probes to know when to restart a container. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixWebService.podAntiAffinity bool true Set permissive podAntiAffinity to spread replicas over cluster nodes if replicaCount>1
zabbixWebService.readinessProbe object {} The kubelet uses readiness probes to know when a container is ready to start accepting traffic. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
zabbixWebService.replicaCount int 1 Number of replicas of zabbixWebService module
zabbixWebService.resources object {} Requests and limits of pod resources. See: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers
zabbixWebService.securityContext object {} Security Context configurations. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
zabbixWebService.service object {"annotations":{},"clusterIP":null,"port":10053,"type":"ClusterIP"} Set the IgnoreURLCertErrors configuration setting of Zabbix Web Service ignoreURLCertErrors=1
zabbixWebService.service.annotations object {} Annotations for the Zabbix Web Service
zabbixWebService.service.clusterIP string nil clusterIP is the IP address of the service and is usually assigned randomly. If an address is specified manually, is in-range (as per system configuration), and is not in use, it will be allocated to the service.
zabbixWebService.service.port int 10053 Port of service in Kubernetes cluster
zabbixWebService.service.type string "ClusterIP" Type of service to expose the application. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. More details: https://kubernetes.io/docs/concepts/services-networking/service/
zabbixWebService.startupProbe object {} The kubelet uses startup probes to know when a container application has started. Reference: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/

Configure central database access related settings

All settings referring to how the different components that this Chart installs access the Zabbix PostgreSQL Database (either an external, already existing database or one deployed within this Helm chart) are being configured centrally under the postgresAccess section of the values.yaml file.

By default, this Chart will deploy it's own very simple PostgreSQL database. All settings relevant to how to access this database will be held in one central unified secret with the name configured with the postgresAccess.unifiedSecretName setting.

Instead of letting the Chart automatically generate such a secret with a random password (which will NOT be recreated on upgrade/redeploy), you can supply such a secret yourself. Use postgresAccess.unifiedSecretAutoCreate=false in such a case and read the comments in values.yaml for how the values inside the secret should be set.

If you want to connect your Zabbix installation to a Postgres database deployed using the CrunchyData PGO Operator, you can use the secret that PGO generates for your DB automatically directly to connect Zabbix to it, by just referring to its name with the postgresAccess.unifiedSecretName setting to it.

There is also the possibility to set all DB relevant settings directly inside the postgresAccess section of the values.yaml file by using the settings noted there (postgres_host, postgres_user, etc). If doing so, you still can use one single secret to told just and only the database password. If you want to do so, supply the postgresAccess.passwordSecret and postgresAccess.passwordSecretKey settings, accordingly.

Configure Postgresql database to match with your performance expectations

While the default database configuration shipped with this Chart is fine for most (very small, for testing only) Zabbix installations, you will want to set some specific settings to better match your setup. First of all, you should consider enabling Postgresql database persistence (postgresql.persistence.enabled), as otherwise all your changes and historical data will be gone as soon as you remove the installation of Zabbix. Additionally, you might want to tune Postgresql by supplying extra postgresql runtime parameters using the postgresql.extraRuntimeParameters dictionary:

postgresql:
  enabled: true
  persistence:
    enabled: true
    storageSize: 50Gi
  extraRuntimeParameters:
    max_connections: 250
    dynamic_shared_memory_type: posix
    shared_buffers: 4GB
    temp_buffers: 16MB
    work_mem: 128MB
    maintenance_work_mem: 256MB
    effective_cache_size: 6GB
    min_wal_size: 80MB

Alternatively, you can add your own configuration file for postgresql (using a ConfigMap and the postgresql.extraVolumes setting) to mount it into the postgresql container and referring to this config file with the postgresql.extraRuntimeParameters set to:

postgresql:
  extraRuntimeParameters:
    config.file: /path/to/your/config.file

Configure the way how to expose Zabbix service

  • Ingress: The ingress controller must be installed in the Kubernetes cluster.
  • ClusterIP: Exposes the service on a cluster-internal IP. Choosing this value makes the service only reachable from within the cluster.
  • NodePort: Exposes the service on each Node's IP at a static port (the NodePort). You'll be able to contact the NodePort service, from outside the cluster, by requesting NodeIP:NodePort.
  • LoadBalancer: Exposes the service externally using a cloud provider's load balancer.