123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391 |
- {{/*
- Default memory limiter configuration for OpenTelemetry Collector based on k8s resource limits.
- */}}
- {{- define "opentelemetry-collector.memoryLimiter" -}}
- # check_interval is the time between measurements of memory usage.
- check_interval: 5s
- # By default limit_mib is set to 80% of ".Values.resources.limits.memory"
- limit_percentage: 80
- # By default spike_limit_mib is set to 25% of ".Values.resources.limits.memory"
- spike_limit_percentage: 25
- {{- end }}
- {{/*
- Merge user supplied config into memory limiter config.
- */}}
- {{- define "opentelemetry-collector.baseConfig" -}}
- {{- $processorsConfig := get .Values.config "processors" }}
- {{- if not $processorsConfig.memory_limiter }}
- {{- $_ := set $processorsConfig "memory_limiter" (include "opentelemetry-collector.memoryLimiter" . | fromYaml) }}
- {{- end }}
- {{- if .Values.useGOMEMLIMIT }}
- {{- if (((.Values.config).service).extensions) }}
- {{- $_ := set .Values.config.service "extensions" (without .Values.config.service.extensions "memory_ballast") }}
- {{- end}}
- {{- $_ := unset (.Values.config.extensions) "memory_ballast" }}
- {{- else }}
- {{- $memoryBallastConfig := get .Values.config.extensions "memory_ballast" }}
- {{- if or (not $memoryBallastConfig) (not $memoryBallastConfig.size_in_percentage) }}
- {{- $_ := set $memoryBallastConfig "size_in_percentage" 40 }}
- {{- end }}
- {{- end }}
- {{- .Values.config | toYaml }}
- {{- end }}
- {{/*
- Build config file for daemonset OpenTelemetry Collector
- */}}
- {{- define "opentelemetry-collector.daemonsetConfig" -}}
- {{- $values := deepCopy .Values }}
- {{- $data := dict "Values" $values | mustMergeOverwrite (deepCopy .) }}
- {{- $config := include "opentelemetry-collector.baseConfig" $data | fromYaml }}
- {{- if .Values.presets.logsCollection.enabled }}
- {{- $config = (include "opentelemetry-collector.applyLogsCollectionConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.hostMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyHostMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.kubeletMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyKubeletMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.kubernetesAttributes.enabled }}
- {{- $config = (include "opentelemetry-collector.applyKubernetesAttributesConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.clusterMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyClusterMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- tpl (toYaml $config) . }}
- {{- end }}
- {{/*
- Build config file for deployment OpenTelemetry Collector
- */}}
- {{- define "opentelemetry-collector.deploymentConfig" -}}
- {{- $values := deepCopy .Values }}
- {{- $data := dict "Values" $values | mustMergeOverwrite (deepCopy .) }}
- {{- $config := include "opentelemetry-collector.baseConfig" $data | fromYaml }}
- {{- if .Values.presets.logsCollection.enabled }}
- {{- $config = (include "opentelemetry-collector.applyLogsCollectionConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.hostMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyHostMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.kubeletMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyKubeletMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.kubernetesAttributes.enabled }}
- {{- $config = (include "opentelemetry-collector.applyKubernetesAttributesConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.kubernetesEvents.enabled }}
- {{- $config = (include "opentelemetry-collector.applyKubernetesEventsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- if .Values.presets.clusterMetrics.enabled }}
- {{- $config = (include "opentelemetry-collector.applyClusterMetricsConfig" (dict "Values" $data "config" $config) | fromYaml) }}
- {{- end }}
- {{- tpl (toYaml $config) . }}
- {{- end }}
- {{- define "opentelemetry-collector.applyHostMetricsConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.hostMetricsConfig" .Values | fromYaml) .config }}
- {{- $_ := set $config.service.pipelines.metrics "receivers" (append $config.service.pipelines.metrics.receivers "hostmetrics" | uniq) }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.hostMetricsConfig" -}}
- receivers:
- hostmetrics:
- root_path: /hostfs
- collection_interval: 10s
- scrapers:
- cpu:
- load:
- memory:
- disk:
- filesystem:
- exclude_mount_points:
- mount_points:
- - /dev/*
- - /proc/*
- - /sys/*
- - /run/k3s/containerd/*
- - /var/lib/docker/*
- - /var/lib/kubelet/*
- - /snap/*
- match_type: regexp
- exclude_fs_types:
- fs_types:
- - autofs
- - binfmt_misc
- - bpf
- - cgroup2
- - configfs
- - debugfs
- - devpts
- - devtmpfs
- - fusectl
- - hugetlbfs
- - iso9660
- - mqueue
- - nsfs
- - overlay
- - proc
- - procfs
- - pstore
- - rpc_pipefs
- - securityfs
- - selinuxfs
- - squashfs
- - sysfs
- - tracefs
- match_type: strict
- network:
- {{- end }}
- {{- define "opentelemetry-collector.applyClusterMetricsConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.clusterMetricsConfig" .Values | fromYaml) .config }}
- {{- $_ := set $config.service.pipelines.metrics "receivers" (append $config.service.pipelines.metrics.receivers "k8s_cluster" | uniq) }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.clusterMetricsConfig" -}}
- receivers:
- k8s_cluster:
- collection_interval: 10s
- {{- end }}
- {{- define "opentelemetry-collector.applyKubeletMetricsConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.kubeletMetricsConfig" .Values | fromYaml) .config }}
- {{- $_ := set $config.service.pipelines.metrics "receivers" (append $config.service.pipelines.metrics.receivers "kubeletstats" | uniq) }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.kubeletMetricsConfig" -}}
- receivers:
- kubeletstats:
- collection_interval: 20s
- auth_type: "serviceAccount"
- endpoint: "${env:K8S_NODE_NAME}:10250"
- {{- end }}
- {{- define "opentelemetry-collector.applyLogsCollectionConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.logsCollectionConfig" .Values | fromYaml) .config }}
- {{- $_ := set $config.service.pipelines.logs "receivers" (append $config.service.pipelines.logs.receivers "filelog" | uniq) }}
- {{- if .Values.Values.presets.logsCollection.storeCheckpoints}}
- {{- $_ := set $config.service "extensions" (append $config.service.extensions "file_storage" | uniq) }}
- {{- end }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.logsCollectionConfig" -}}
- {{- if .Values.presets.logsCollection.storeCheckpoints }}
- extensions:
- file_storage:
- directory: /var/lib/otelcol
- {{- end }}
- receivers:
- filelog:
- include: [ /var/log/pods/*/*/*.log ]
- {{- if .Values.presets.logsCollection.includeCollectorLogs }}
- exclude: []
- {{- else }}
- # Exclude collector container's logs. The file format is /var/log/pods/<namespace_name>_<pod_name>_<pod_uid>/<container_name>/<run_id>.log
- exclude: [ /var/log/pods/{{ include "opentelemetry-collector.namespace" . }}_{{ include "opentelemetry-collector.fullname" . }}*_*/{{ include "opentelemetry-collector.lowercase_chartname" . }}/*.log ]
- {{- end }}
- start_at: end
- retry_on_failure:
- enabled: true
- {{- if .Values.presets.logsCollection.storeCheckpoints}}
- storage: file_storage
- {{- end }}
- include_file_path: true
- include_file_name: false
- operators:
- # Find out which format is used by kubernetes
- - type: router
- id: get-format
- routes:
- - output: parser-docker
- expr: 'body matches "^\\{"'
- - output: parser-crio
- expr: 'body matches "^[^ Z]+ "'
- - output: parser-containerd
- expr: 'body matches "^[^ Z]+Z"'
- # Parse CRI-O format
- - type: regex_parser
- id: parser-crio
- regex: '^(?P<time>[^ Z]+) (?P<stream>stdout|stderr) (?P<logtag>[^ ]*) ?(?P<log>.*)$'
- timestamp:
- parse_from: attributes.time
- layout_type: gotime
- layout: '2006-01-02T15:04:05.999999999Z07:00'
- - type: recombine
- id: crio-recombine
- output: extract_metadata_from_filepath
- combine_field: attributes.log
- source_identifier: attributes["log.file.path"]
- is_last_entry: "attributes.logtag == 'F'"
- combine_with: ""
- max_log_size: {{ $.Values.presets.logsCollection.maxRecombineLogSize }}
- # Parse CRI-Containerd format
- - type: regex_parser
- id: parser-containerd
- regex: '^(?P<time>[^ ^Z]+Z) (?P<stream>stdout|stderr) (?P<logtag>[^ ]*) ?(?P<log>.*)$'
- timestamp:
- parse_from: attributes.time
- layout: '%Y-%m-%dT%H:%M:%S.%LZ'
- - type: recombine
- id: containerd-recombine
- output: extract_metadata_from_filepath
- combine_field: attributes.log
- source_identifier: attributes["log.file.path"]
- is_last_entry: "attributes.logtag == 'F'"
- combine_with: ""
- max_log_size: {{ $.Values.presets.logsCollection.maxRecombineLogSize }}
- # Parse Docker format
- - type: json_parser
- id: parser-docker
- output: extract_metadata_from_filepath
- timestamp:
- parse_from: attributes.time
- layout: '%Y-%m-%dT%H:%M:%S.%LZ'
- # Extract metadata from file path
- - type: regex_parser
- id: extract_metadata_from_filepath
- regex: '^.*\/(?P<namespace>[^_]+)_(?P<pod_name>[^_]+)_(?P<uid>[a-f0-9\-]+)\/(?P<container_name>[^\._]+)\/(?P<restart_count>\d+)\.log$'
- parse_from: attributes["log.file.path"]
- # Rename attributes
- - type: move
- from: attributes.stream
- to: attributes["log.iostream"]
- - type: move
- from: attributes.container_name
- to: resource["k8s.container.name"]
- - type: move
- from: attributes.namespace
- to: resource["k8s.namespace.name"]
- - type: move
- from: attributes.pod_name
- to: resource["k8s.pod.name"]
- - type: move
- from: attributes.restart_count
- to: resource["k8s.container.restart_count"]
- - type: move
- from: attributes.uid
- to: resource["k8s.pod.uid"]
- # Clean up log body
- - type: move
- from: attributes.log
- to: body
- {{- end }}
- {{- define "opentelemetry-collector.applyKubernetesAttributesConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.kubernetesAttributesConfig" .Values | fromYaml) .config }}
- {{- if and ($config.service.pipelines.logs) (not (has "k8sattributes" $config.service.pipelines.logs.processors)) }}
- {{- $_ := set $config.service.pipelines.logs "processors" (prepend $config.service.pipelines.logs.processors "k8sattributes" | uniq) }}
- {{- end }}
- {{- if and ($config.service.pipelines.metrics) (not (has "k8sattributes" $config.service.pipelines.metrics.processors)) }}
- {{- $_ := set $config.service.pipelines.metrics "processors" (prepend $config.service.pipelines.metrics.processors "k8sattributes" | uniq) }}
- {{- end }}
- {{- if and ($config.service.pipelines.traces) (not (has "k8sattributes" $config.service.pipelines.traces.processors)) }}
- {{- $_ := set $config.service.pipelines.traces "processors" (prepend $config.service.pipelines.traces.processors "k8sattributes" | uniq) }}
- {{- end }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.kubernetesAttributesConfig" -}}
- processors:
- k8sattributes:
- {{- if eq .Values.mode "daemonset" }}
- filter:
- node_from_env_var: K8S_NODE_NAME
- {{- end }}
- passthrough: false
- pod_association:
- - sources:
- - from: resource_attribute
- name: k8s.pod.ip
- - sources:
- - from: resource_attribute
- name: k8s.pod.uid
- - sources:
- - from: connection
- extract:
- metadata:
- - "k8s.namespace.name"
- - "k8s.deployment.name"
- - "k8s.statefulset.name"
- - "k8s.daemonset.name"
- - "k8s.cronjob.name"
- - "k8s.job.name"
- - "k8s.node.name"
- - "k8s.pod.name"
- - "k8s.pod.uid"
- - "k8s.pod.start_time"
- {{- if .Values.presets.kubernetesAttributes.extractAllPodLabels }}
- labels:
- - tag_name: $$1
- key_regex: (.*)
- from: pod
- {{- end }}
- {{- if .Values.presets.kubernetesAttributes.extractAllPodAnnotations }}
- annotations:
- - tag_name: $$1
- key_regex: (.*)
- from: pod
- {{- end }}
- {{- end }}
- {{/* Build the list of port for service */}}
- {{- define "opentelemetry-collector.servicePortsConfig" -}}
- {{- $ports := deepCopy .Values.ports }}
- {{- range $key, $port := $ports }}
- {{- if $port.enabled }}
- - name: {{ $key }}
- port: {{ $port.servicePort }}
- targetPort: {{ $port.containerPort }}
- protocol: {{ $port.protocol }}
- {{- if $port.appProtocol }}
- appProtocol: {{ $port.appProtocol }}
- {{- end }}
- {{- if $port.nodePort }}
- nodePort: {{ $port.nodePort }}
- {{- end }}
- {{- end }}
- {{- end }}
- {{- end }}
- {{/* Build the list of port for pod */}}
- {{- define "opentelemetry-collector.podPortsConfig" -}}
- {{- $ports := deepCopy .Values.ports }}
- {{- range $key, $port := $ports }}
- {{- if $port.enabled }}
- - name: {{ $key }}
- containerPort: {{ $port.containerPort }}
- protocol: {{ $port.protocol }}
- {{- if and $.isAgent $port.hostPort }}
- hostPort: {{ $port.hostPort }}
- {{- end }}
- {{- end }}
- {{- end }}
- {{- end }}
- {{- define "opentelemetry-collector.applyKubernetesEventsConfig" -}}
- {{- $config := mustMergeOverwrite (include "opentelemetry-collector.kubernetesEventsConfig" .Values | fromYaml) .config }}
- {{- $_ := set $config.service.pipelines.logs "receivers" (append $config.service.pipelines.logs.receivers "k8sobjects" | uniq) }}
- {{- $config | toYaml }}
- {{- end }}
- {{- define "opentelemetry-collector.kubernetesEventsConfig" -}}
- receivers:
- k8sobjects:
- objects:
- - name: events
- mode: "watch"
- group: "events.k8s.io"
- exclude_watch_type:
- - "DELETED"
- {{- end }}
|