falco-exporter is a Prometheus Metrics Exporter for Falco output events.
Before using this chart, you need Falco installed and running with the gRPC Output enabled (over Unix socket by default).
This chart is compatible with the Falco Chart version v1.2.0
or greater. Instructions to enable the gRPC Output in the Falco Helm Chart can be found here. We also strongly recommend using gRPC over Unix socket.
The chart deploys falco-exporter as Daemon Set on your the Kubernetes cluster. If a Prometheus installation is running within your cluster, metrics provided by falco-exporter will be automatically discovered.
Prior to installing the chart, add the falcosecurity
charts repository:
helm repo add falcosecurity https://falcosecurity.github.io/charts
helm repo update
To install the chart with the release name falco-exporter
run:
helm install falco-exporter falcosecurity/falco-exporter
After a few seconds, falco-exporter should be running.
Tip: List all releases using
helm list
, a release is a name used to track a specific deployment
To uninstall the falco-exporter
deployment:
helm uninstall falco-exporter
The command removes all the Kubernetes components associated with the chart and deletes the release.
helm install falco-exporter --set falco.grpcTimeout=3m falcosecurity/falco-exporter
Alternatively, a YAML file that specifies the parameters' values can be provided while installing the chart. For example,
helm install falco-exporter -f values.yaml falcosecurity/falco-exporter
Mutual TLS for /metrics
endpoint can be enabled to prevent alerts content from being consumed by unauthorized components.
To install falco-exporter with Mutual TLS enabled, you have to:
helm install falco-exporter \
--set service.mTLS.enabled=true \
--set-file service.mTLS.server.key=/path/to/server.key \
--set-file service.mTLS.server.crt=/path/to/server.crt \
--set-file service.mTLS.ca.crt=/path/to/ca.crt \
falcosecurity/falco-exporter
Tip: You can use the default values.yaml
The following table lists the main configurable parameters of the falco-exporter chart v0.12.1 and their default values. Please, refer to values.yaml for the full list of configurable parameters.
Key | Type | Default | Description |
---|---|---|---|
affinity | object | {} |
affinity allows pod placement based on node characteristics, or any other custom labels assigned to nodes. |
daemonset | object | {"annotations":{},"podLabels":{},"updateStrategy":{"type":"RollingUpdate"}} |
daemonset holds the configuration for the daemonset. |
daemonset.annotations | object | {} |
annotations to add to the DaemonSet pods. |
daemonset.podLabels | object | {} |
podLabels labels to add to the pods. |
falco | object | {"grpcTimeout":"2m","grpcUnixSocketPath":"unix:///run/falco/falco.sock"} |
falco the configuration to connect falco. |
falco.grpcTimeout | string | "2m" |
grpcTimeout timout value for grpc connection. |
falco.grpcUnixSocketPath | string | "unix:///run/falco/falco.sock" |
grpcUnixSocketPath path to the falco's grpc unix socket. |
fullnameOverride | string | "" |
fullNameOverride same as nameOverride but for the full name. |
grafanaDashboard | object | {"enabled":false,"folder":"","folderAnnotation":"grafana_dashboard_folder","namespace":"default","prometheusDatasourceName":"Prometheus"} |
grafanaDashboard contains the configuration related to grafana dashboards. |
grafanaDashboard.enabled | bool | false |
enabled specifies whether the dashboard should be deployed. |
grafanaDashboard.folder | string | "" |
folder creates and set folderAnnotation to specify where the dashboard is stored in grafana. |
grafanaDashboard.folderAnnotation | string | "grafana_dashboard_folder" |
folderAnnotation sets the annotation's name used by folderAnnotation in grafana's helm-chart. |
grafanaDashboard.namespace | string | "default" |
namespace specifies the namespace for the configmap. |
grafanaDashboard.prometheusDatasourceName | string | "Prometheus" |
prometheusDatasourceName name of the data source. |
healthChecks | object | {"livenessProbe":{"initialDelaySeconds":60,"periodSeconds":15,"probesPort":19376,"timeoutSeconds":5},"readinessProbe":{"initialDelaySeconds":30,"periodSeconds":15,"probesPort":19376,"timeoutSeconds":5}} |
healthChecks contains the configuration for liveness and readiness probes. |
healthChecks.livenessProbe | object | {"initialDelaySeconds":60,"periodSeconds":15,"probesPort":19376,"timeoutSeconds":5} |
livenessProbe is a diagnostic mechanism used to determine weather a container within a Pod is still running and healthy. |
healthChecks.livenessProbe.initialDelaySeconds | int | 60 |
initialDelaySeconds tells the kubelet that it should wait X seconds before performing the first probe. |
healthChecks.livenessProbe.periodSeconds | int | 15 |
periodSeconds specifies the interval at which the liveness probe will be repeated. |
healthChecks.livenessProbe.probesPort | int | 19376 |
probesPort is liveness probes port. |
healthChecks.livenessProbe.timeoutSeconds | int | 5 |
timeoutSeconds number of seconds after which the probe times out. |
healthChecks.readinessProbe | object | {"initialDelaySeconds":30,"periodSeconds":15,"probesPort":19376,"timeoutSeconds":5} |
readinessProbe is a mechanism used to determine whether a container within a Pod is ready to serve traffic. |
healthChecks.readinessProbe.initialDelaySeconds | int | 30 |
initialDelaySeconds tells the kubelet that it should wait X seconds before performing the first probe. |
healthChecks.readinessProbe.periodSeconds | int | 15 |
periodSeconds specifies the interval at which the readiness probe will be repeated. |
healthChecks.readinessProbe.timeoutSeconds | int | 5 |
timeoutSeconds is the number of seconds after which the probe times out. |
image | object | {"pullPolicy":"IfNotPresent","registry":"docker.io","repository":"falcosecurity/falco-exporter","tag":"0.8.3"} |
image is the configuration for the exporter image. |
image.pullPolicy | string | "IfNotPresent" |
pullPolicy is the policy used to determine when a node should attempt to pull the container image. |
image.registry | string | "docker.io" |
registry is the image registry to pull from. |
image.repository | string | "falcosecurity/falco-exporter" |
repository is the image repository to pull from. |
image.tag | string | "0.8.3" |
tag is image tag to pull. |
imagePullSecrets | list | [] |
pullSecrets a list of secrets containing credentials used when pulling from private/secure registries. |
nameOverride | string | "" |
nameOverride is the new name used to override the release name used for exporter's components. |
nodeSelector | object | {} |
nodeSelector specifies a set of key-value pairs that must match labels assigned to nodes for the Pod to be eligible for scheduling on that node |
podSecurityContext | object | {} |
podSecurityPolicy holds the security policy settings for the pod. |
podSecurityPolicy | object | {"annotations":{},"create":false,"name":""} |
podSecurityPolicy holds the security policy settings for the pod. |
podSecurityPolicy.annotations | object | {} |
annotations to add to the PSP, Role and RoleBinding |
podSecurityPolicy.create | bool | false |
create specifies whether a PSP, Role and RoleBinding should be created |
podSecurityPolicy.name | string | "" |
name of the PSP, Role and RoleBinding to use. If not set and create is true, a name is generated using the fullname template |
priorityClassName | string | "" |
priorityClassName specifies the name of the PriorityClass for the pods. |
prometheusRules.alerts.additionalAlerts | object | {} |
|
prometheusRules.alerts.alert.enabled | bool | true |
|
prometheusRules.alerts.alert.for | string | "5m" |
|
prometheusRules.alerts.alert.rate_interval | string | "5m" |
|
prometheusRules.alerts.alert.threshold | int | 0 |
|
prometheusRules.alerts.critical.enabled | bool | true |
|
prometheusRules.alerts.critical.for | string | "15m" |
|
prometheusRules.alerts.critical.rate_interval | string | "5m" |
|
prometheusRules.alerts.critical.threshold | int | 0 |
|
prometheusRules.alerts.emergency.enabled | bool | true |
|
prometheusRules.alerts.emergency.for | string | "1m" |
|
prometheusRules.alerts.emergency.rate_interval | string | "1m" |
|
prometheusRules.alerts.emergency.threshold | int | 0 |
|
prometheusRules.alerts.error.enabled | bool | true |
|
prometheusRules.alerts.error.for | string | "15m" |
|
prometheusRules.alerts.error.rate_interval | string | "5m" |
|
prometheusRules.alerts.error.threshold | int | 0 |
|
prometheusRules.alerts.warning.enabled | bool | true |
|
prometheusRules.alerts.warning.for | string | "15m" |
|
prometheusRules.alerts.warning.rate_interval | string | "5m" |
|
prometheusRules.alerts.warning.threshold | int | 0 |
|
prometheusRules.enabled | bool | false |
enabled specifies whether the prometheus rules should be deployed. |
resources | object | {} |
resources defines the computing resources (CPU and memory) that are allocated to the containers running within the Pod. |
scc.create | bool | true |
|
securityContext | object | {"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"privileged":false,"readOnlyRootFilesystem":true,"seccompProfile":{"type":"RuntimeDefault"}} |
securityContext holds the security context for the daemonset. |
securityContext.capabilities | object | {"drop":["ALL"]} |
capabilities to be assigned to the daemonset. |
service | object | {"annotations":{"prometheus.io/port":"9376","prometheus.io/scrape":"true"},"clusterIP":"None","labels":{},"mTLS":{"enabled":false},"port":9376,"targetPort":9376,"type":"ClusterIP"} |
service exposes the exporter service to be accessed from within the cluster. |
service.annotations | object | {"prometheus.io/port":"9376","prometheus.io/scrape":"true"} |
annotations set of annotations to be applied to the service. |
service.clusterIP | string | "None" |
clusterIP set to none. It's headless service. |
service.labels | object | {} |
labels set of labels to be applied to the service. |
service.mTLS | object | {"enabled":false} |
mTLS mutual TLS for HTTP metrics server. |
service.mTLS.enabled | bool | false |
enabled specifies whether the mTLS should be enabled. |
service.port | int | 9376 |
port is the port on which the Service will listen. |
service.targetPort | int | 9376 |
targetPort is the port on which the Pod is listening. |
service.type | string | "ClusterIP" |
type denotes the service type. Setting it to "ClusterIP" we ensure that are accessible from within the cluster. |
serviceAccount | object | {"annotations":{},"create":true,"name":""} |
serviceAccount is the configuration for the service account. |
serviceAccount.name | string | "" |
name is the name of the service account to use. If not set and create is true, a name is generated using the fullname template. If set and create is false, an already existing serviceAccount must be provided. |
serviceMonitor | object | {"additionalLabels":{},"additionalProperties":{},"enabled":false,"interval":"","scrapeTimeout":""} |
serviceMonitor holds the configuration for the ServiceMonitor CRD. A ServiceMonitor is a custom resource definition (CRD) used to configure how Prometheus should discover and scrape metrics from the exporter service. |
serviceMonitor.additionalLabels | object | {} |
additionalLabels specifies labels to be added on the Service Monitor. |
serviceMonitor.additionalProperties | object | {} |
aditionalProperties allows setting additional properties on the endpoint such as relabelings, metricRelabelings etc. |
serviceMonitor.enabled | bool | false |
enable the deployment of a Service Monitor for the Prometheus Operator. |
serviceMonitor.interval | string | "" |
interval specifies the time interval at which Prometheus should scrape metrics from the service. |
serviceMonitor.scrapeTimeout | string | "" |
scrapeTimeout determines the maximum time Prometheus should wait for a target to respond to a scrape request. If the target does not respond within the specified timeout, Prometheus considers the scrape as failed for that target. |
tolerations | list | [{"effect":"NoSchedule","key":"node-role.kubernetes.io/master"},{"effect":"NoSchedule","key":"node-role.kubernetes.io/control-plane"}] |
tolerations are applied to pods and allow them to be scheduled on nodes with matching taints. |