Skip to content

Bufstream Helm values

The Bufstream Helm chart is used to deploy Bufstream on Kubernetes. The Bufstream Helm values.yaml file defines the configuration for the Bufstream Kubernetes cluster. The configuration parameters and defaults documented below are the common and recommended settings for deploying a Bufstream cluster.

Values and defaults

adminTLS

object

adminTLS contains TLS configuration for Admin Server.

Defaults to {}.

bufstream.controlServerService.annotations

object

Kubernetes Service annotations.

Defaults to {}.

bufstream.controlServerService.enabled

bool

Whether to create a Kubernetes Headless Service for the Bufstream Control Server (inter-agent RPC server using the Connect protocol).

Defaults to false.

bufstream.deployment.affinity

object

Bufstream Deployment Affinity.

Defaults to {}.

bufstream.deployment.args

list

Bufstream Deployment args to be appended.

Defaults to [].

bufstream.deployment.autoscaling.behavior

object

Horizontal Pod Autoscaler behavior.

Defaults to {}.

bufstream.deployment.autoscaling.enabled

bool

Whether to enable the horizontal pod autoscaler.

Defaults to false.

bufstream.deployment.autoscaling.maxReplicas

int

Maximum number of autoscaler allowed replicas.

Defaults to 18.

bufstream.deployment.autoscaling.minReplicas

int

Minimum number of autoscaler allowed replicas.

Defaults to 6.

bufstream.deployment.autoscaling.targetCPU

string

Target CPU threshold for managing replica count.

Defaults to "50".

bufstream.deployment.autoscaling.targetMemory

string

Target memory threshold for managing replica count.

Defaults to "".

bufstream.deployment.command

list

Bufstream Deployment command.

Defaults to ["/usr/local/bin/bufstream"].

bufstream.deployment.extraContainerPorts

object

Bufstream Deployment Extra container ports for the bufstream container.

Defaults to {}.

bufstream.deployment.extraContainers

list

Bufstream Deployment additional containers to run besides the bufstream container.

Defaults to [].

bufstream.deployment.extraEnv

list

Bufstream Deployment Extra environment variables for the bufstream container.

Defaults to [].

bufstream.deployment.extraVolumeMounts

list

Bufstream Deployment Extra volume mounts for the bufstream container.

Defaults to [].

bufstream.deployment.extraVolumes

list

Bufstream Deployment Extra volumes.

Defaults to [].

bufstream.deployment.kind

string

Bufstream Deployment kind. Supports [Deployment, StatefulSet]

Defaults to "StatefulSet".

bufstream.deployment.livenessProbe.failureThreshold

int

Bufstream Deployment Liveness Probe Maximum failure threshold.

Defaults to 3.

bufstream.deployment.livenessProbe.timeoutSeconds

int

Bufstream Deployment Liveness Probe timeout.

Defaults to 5.

bufstream.deployment.nodeSelector

object

Bufstream Deployment Node selector.

Defaults to {}.

bufstream.deployment.podAnnotations

object

Bufstream Deployment Pod annotations.

Defaults to {}.

bufstream.deployment.podLabels

object

Bufstream Deployment Pod labels.

Defaults to {}.

bufstream.deployment.podManagementPolicy

string

Bufstream Deployment pod management policy to use when StatefulSet kind is used.

Defaults to "Parallel".

bufstream.deployment.readinessProbe.failureThreshold

int

Bufstream Deployment Readiness Probe Maximum failure threshold.

Defaults to 3.

bufstream.deployment.readinessProbe.timeoutSeconds

int

Bufstream Deployment Readiness Probe timeout.

Defaults to 5.

bufstream.deployment.replicaCount

int

Bufstream Deployment replica count.

Defaults to 3.

bufstream.deployment.resources.limits.cpu

string

Bufstream Deployment Resource request CPU.

Defaults to "".

bufstream.deployment.resources.limits.memory

string

Bufstream Deployment Resource limits memory.

Defaults to "8Gi".

bufstream.deployment.resources.requests.cpu

int

Bufstream Deployment Resource request CPU.

Defaults to 2.

bufstream.deployment.resources.requests.memory

string

Bufstream Deployment Resource request memory.

Defaults to "8Gi".

bufstream.deployment.selectorLabels

object

Bufstream Deployment Selector labels.

Defaults to {}.

bufstream.deployment.serviceName

string

Bufstream Deployment service name to link for per pod DNS registration when StatefulSet kind is used.

Defaults to "".

bufstream.deployment.shareProcessNamespace

bool

Bufstream Deployment setting for sharing the process namespace.

Defaults to false.

bufstream.deployment.startupProbe.failureThreshold

int

Bufstream Deployment Liveness Probe Configuration

Defaults to 3.

bufstream.deployment.terminationGracePeriodSeconds

int

Bufstream Deployment termination grace period.

Defaults to 420.

bufstream.deployment.tolerations

list

Bufstream Deployment Tolerations.

Defaults to [].

bufstream.image.pullPolicy

string

Bufstream Deployment container image pull policy.

Defaults to "IfNotPresent".

bufstream.image.repository

string

Bufstream Deployment container image repository.

Defaults to "us-docker.pkg.dev/buf-images-1/bufstream-public/images/bufstream".

bufstream.image.tag

string

Overrides the image tag whose default is the chart version.

Defaults to "latest".

bufstream.podDisruptionBudget.enabled

bool

Whether to enable pod disruption budget.

Defaults to false.

bufstream.podDisruptionBudget.maxUnavailable

string

Number of pods that are unavailable after eviction as number or percentage (eg.: 50%). Has higher precedence over minAvailable

Defaults to "".

bufstream.podDisruptionBudget.minAvailable

string

Number of pods that are available after eviction as number or percentage (eg.: 50%).

Defaults to "" (defaults to 0 if not specified).

bufstream.service.annotations

object

Kubernetes Service annotations.

Defaults to {}.

bufstream.service.enabled

bool

Whether to create a Kubernetes Service for this bufstream deployment.

Defaults to true.

bufstream.service.type

string

Kubernetes Service type.

Defaults to "ClusterIP".

bufstream.serviceAccount.annotations

object

Kubernetes Service Account annotations.

Defaults to {}.

bufstream.serviceAccount.create

bool

Whether to create a Kubernetes Service Account for this bufstream deployment.

Defaults to true.

bufstream.serviceAccount.name

string

Kubernetes Service Account name.

Defaults to "bufstream-service-account".

cluster

string

The name of the cluster. Used by bufstream to identify itself.

Defaults to "bufstream".

configOverrides

object

Bufstream configuration overrides. Any value here will be set directly on the bufstream config.yaml, taking precedence over any other helm defined values.

Defaults to {}.

connectTLS

object

connectTLS contains TLS configuration for Control Server which is used for inter-agent communication using Connect protocol.

Defaults to {"client":{},"server":{}}.

connectTLS.client

object

Client contains client side TLS configuration to connect to the Control Server.

Defaults to {}.

connectTLS.server

object

Server contains server side TLS configuration.

Defaults to {}.

dataEnforcement

object

Configuration for data enforcement via schemas of records flowing in and out of the agent.

Defaults to {}.

discoverZoneFromNode

bool

When true it enables additional permissions so Bufstream can get the zone via the Kubernetes API server by reading the zone topology label of the node the bufstream pod is running on. Bufstream won't attempt to do the discovery if the zone option is false.

Defaults to false.

extraObjects

list

Extra Kubernetes objects to install as part of this chart.

Defaults to [].

imagePullSecrets

list

Reference to one or more secrets to be used when pulling images. For more information, see Pull an Image from a Private Registry.

Defaults to [].

kafka.address

object

The address the Kafka server should listen on. This defaults to 0.0.0.0 (any) and 9092 port.

Defaults to {"host":"0.0.0.0","port":9092}.

kafka.exactLogOffsets

bool

If exact log hwm and start offsets should be computed when fetching records.

Defaults to false.

kafka.exactLogSizes

bool

If exact log sizes should be fetched when listing sizes for all topics/partitions.

Defaults to true.

kafka.fetchEager

bool

If a fetch should return as soon as any records are available.

Defaults to true.

kafka.fetchSync

bool

If fetches from different readers should be synchronized to improve cache hit rates.

Defaults to true.

kafka.groupConsumerSessionTimeout

string

The default group consumer session timeout.

Defaults to "45s".

kafka.groupConsumerSessionTimeoutMax

string

The maximum group consumer session timeout.

Defaults to "60s".

kafka.groupConsumerSessionTimeoutMin

string

The minimum group consumer session timeout.

Defaults to "10s".

kafka.idleTimeout

int

How long a Kafka connection can be idle before being closed by the server. If set a value less than or equal to zero, the timeout will be disabled.

Defaults to 0.

kafka.numPartitions

int

The default number of partitions to use for a new topic.

Defaults to 1.

kafka.partitionBalanceStrategy

string

How to balance topic/partitions across bufstream nodes. One of: ["BALANCE_STRATEGY_UNSPECIFIED", "BALANCE_STRATEGY_PARTITION", "BALANCE_STRATEGY_HOST", "BALANCE_STRATEGY_CLIENT_ID"]

Defaults to "BALANCE_STRATEGY_PARTITION".

kafka.produceConcurrent

bool

If records from a producer to different topic/partitions may be sequenced concurrently instead of serially.

Defaults to true.

kafka.publicAddress

object

The public address clients should use to connect to the Kafka server. This defaults to the K8S service DNS and 9092 port.

Defaults to {host: "<service>.<namespace>.svc.cluster.local", port: 9092}.

kafka.requestBufferSize

int

The number of kafka request to unmarshal and buffer before processing.

Defaults to 5.

kafka.tlsCertificateSecrets

list

Kubernetes secrets containing a tls.crt and tls.key (as the secret keys, see https://kubernetes.io/docs/concepts/configuration/secret/#tls-secrets) to present to the client. The first certificate compatible with the client's requirements is selected automatically.

Defaults to [].

kafka.tlsClientAuth

string

Declare the policy the server will follow for mutual TLS (mTLS). Supported values are [NO_CERT, REQUEST_CERT, REQUIRE_CERT, VERIFY_CERT_IF_GIVEN, REQUIRE_AND_VERIFY_CERT]. Only supported when using tlsCertificateSecret.

Defaults to "NO_CERT".

kafka.tlsClientCasSecret

string

Kubernetes secret containing a tls.crt (as the secret key) PEM-encoded certificate authorities used by the server to validate the client certificates. This field cannot be empty if tlsClientAuth is set for client performing verification. Only supported when using tlsCertificateSecret.

Defaults to "".

kafka.zoneBalanceStrategy

string

How to balance clients across zones, when client does not specify a zone. One of: ["BALANCE_STRATEGY_UNSPECIFIED", "BALANCE_STRATEGY_PARTITION", "BALANCE_STRATEGY_HOST", "BALANCE_STRATEGY_CLIENT_ID"]

Defaults to "BALANCE_STRATEGY_PARTITION".

metadata.etcd.addresses

list

Etcd addresses to connect to.

Defaults to [].

metadata.etcd.tls

object

TLS client configuration for bufstream to connect to etcd.

Defaults to {}.

metadata.use

string

Which metadata storage that bufstream is using. Currently, only etcd is supported.

Defaults to "etcd".

nameOverride

string

Overrides .Chart.Name throughout the chart.

Defaults to "".

namespaceCreate

bool

Whether to create the namespace where resources are located.

Defaults to false.

namespaceOverride

string

Will be used as the namespace for all resources instead of .Release.namespace if set

Defaults to "".

observability.exporter.address

string

Open Telemetry base endpoint to push metrics and traces. The value has a host and an optional port. It should not include the URL path, such as "/v1/traces" or the scheme. This can be overriden by metrics.address or tracing.address.

Defaults to "".

observability.exporter.insecure

bool

Whether to disable TLS for the exporter's HTTP connection. This can be overriden by metrics.insecure or tracing.insecure.

Defaults to false.

observability.logLevel

string

Log level to use.

Defaults to "INFO".

observability.metrics.address

string

The endpoint the exporter connects to. The value has a host and an optional port. It should not include the URL path, such as "/v1/metrics" or the scheme. Specify path and insecure instead.

Defaults to "".

observability.metrics.aggregation.consumerGroups

bool

Defaults to false.

observability.metrics.aggregation.partitions

bool

Defaults to false.

observability.metrics.aggregation.topics

bool

Defaults to false.

observability.metrics.exporter

string

Open Telemetry exporter. Supports [NONE, STDOUT, HTTP, HTTPS, PROMETHEUS]. Deprecated: use exporterType instead.

Defaults to "".

observability.metrics.exporterType

string

Open Telemetry exporter. Supports [NONE, STDOUT, OTLP_GRPC, OTLP_HTTP, PROMETHEUS]

Defaults to "NONE".

observability.metrics.insecure

bool

Whether to disable TLS. This can only be specified for OTLP_HTTP exporter type.

Defaults to false.

observability.metrics.otlpTemporalityPreference

string

Defaults to "".

observability.metrics.path

string

Defaults to "".

observability.otlpEndpoint

string

Open Telemetry base endpoint to push metrics and traces to. Deprecated: use exporter.address and exporter.insecure instead.

Defaults to "".

observability.sensitiveInformationRedaction

string

Redact sensitive information such as topic names, before adding to to metrics, traces and logs. Supports [NONE, OPAQUE]

Defaults to "NONE".

observability.tracing.address

string

The endpoint the exporter connects to. The value has a host and an optional port. It should not include the URL path, such as "/v1/traces" or the scheme. Specify path and insecure instead.

Defaults to "".

observability.tracing.exporter

string

Open Telemetry exporter. Supports [NONE, STDOUT, HTTP, HTTPS]. Deprecated: use exporterType instead.

Defaults to "".

observability.tracing.exporterType

string

Open Telemetry exporter. Supports [NONE, STDOUT, OTLP_GRPC, OTLP_HTTP]

Defaults to "NONE".

observability.tracing.insecure

bool

Whether to disable TLS. This can only be specified for OTLP_HTTP exporter type.

Defaults to false.

observability.tracing.path

string

Defaults to "".

observability.tracing.traceRatio

float

Trace sample ratio.

Defaults to 0.1.

storage.gcs.bucket

string

GCS bucket name.

Defaults to "".

storage.gcs.prefix

string

GCS prefix to use for all stored files.

Defaults to "".

storage.gcs.secretName

string

Kubernetes secret containing a credentials.json (as the secret key) service account key to use instead of the metadata server.

Defaults to "".

storage.s3.accessKeyId

string

S3 Access Key ID to use instead of the metadata server.

Defaults to "".

storage.s3.bucket

string

S3 bucket name.

Defaults to "".

storage.s3.forcePathStyle

bool

S3 Force Path Style setting. See https://docs.aws.amazon.com/sdk-for-java/latest/developer-guide/examples-s3.html.

Defaults to false.

storage.s3.prefix

string

S3 prefix to use for all stored files.

Defaults to "".

storage.s3.region

string

S3 bucket region.

Defaults to "".

storage.s3.secretName

string

Kubernetes secret containing a secret_access_key (as the secret key) to use instead of the metadata server.

Defaults to "".

storage.use

string

Which object storage that bufstream is using. Currently, gcs and s3 are supported.

Defaults to "s3".

zone

string

The zone location of brokers, e.g., the datacenter/availability zone where the agent is running. If not given, bustream will try to infer this from node metadata. This is currently for bufstream internal functionality, and does not control cloud providers such as GCP directly.

Defaults to "".

Annotated values.yaml

The Helm values.yaml file below contains all of the configuration parameters for a Bufstream cluster with recomemnded defaults. You can copy this annotated YAML into your Helm values file to use as a reference when configuring and deploying Bufstream.

# -- Overrides .Chart.Name throughout the chart.
nameOverride: ""
# -- Will be used as the namespace for all resources instead of .Release.namespace if set
namespaceOverride: ""
# -- Whether to create the namespace where resources are located.
namespaceCreate: false
# -- Reference to one or more secrets to be used when pulling images.
# For more information, see [Pull an Image from a Private Registry](https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/).
imagePullSecrets: []
# -- The name of the cluster. Used by bufstream to identify itself.
cluster: bufstream
# -- The zone location of brokers, e.g., the datacenter/availability zone where the agent is running.
# If not given, bustream will try to infer this from node metadata.
# This is currently for bufstream internal functionality, and does not control cloud providers such as GCP directly.
zone: ""
# -- When true it enables additional permissions so Bufstream can get the zone via the Kubernetes API server by reading the zone topology label of the node the bufstream pod is running on. Bufstream won't attempt to do the discovery if the zone option is false.
discoverZoneFromNode: false
# -- Configuration for data enforcement via schemas of records flowing in and out of the agent.
dataEnforcement: {}
kafka:
  # -- The address the Kafka server should listen on. This defaults to 0.0.0.0 (any) and 9092 port.
  address:
    host: 0.0.0.0
    port: 9092
  # -- The public address clients should use to connect to the Kafka server. This defaults to the K8S service DNS and 9092 port.
  # @default -- `{host: "<service>.<namespace>.svc.cluster.local", port: 9092}`
  publicAddress: {}
  # -- Kubernetes secrets containing a `tls.crt` and `tls.key` (as the secret keys, see https://kubernetes.io/docs/concepts/configuration/secret/#tls-secrets) to present to the client. The first certificate compatible with the client's requirements is selected automatically.
  tlsCertificateSecrets: []
  # -- Declare the policy the server will follow for mutual TLS (mTLS). Supported values are [NO_CERT, REQUEST_CERT, REQUIRE_CERT, VERIFY_CERT_IF_GIVEN, REQUIRE_AND_VERIFY_CERT]. Only supported when using tlsCertificateSecret.
  # @default -- `"NO_CERT"`
  tlsClientAuth: ""
  # -- Kubernetes secret containing a `tls.crt` (as the secret key) PEM-encoded certificate authorities used by the server to validate the client certificates. This field cannot be empty if tlsClientAuth is set for client performing verification. Only supported when using tlsCertificateSecret.
  tlsClientCasSecret: ""
  # -- If a fetch should return as soon as any records are available.
  fetchEager: true
  # -- If fetches from different readers should be synchronized to improve cache hit rates.
  fetchSync: true
  # -- If records from a producer to different topic/partitions may be sequenced concurrently instead of serially.
  produceConcurrent: true
  # -- How to balance clients across zones, when client does not specify a zone. One of: ["BALANCE_STRATEGY_UNSPECIFIED", "BALANCE_STRATEGY_PARTITION", "BALANCE_STRATEGY_HOST", "BALANCE_STRATEGY_CLIENT_ID"]
  zoneBalanceStrategy: BALANCE_STRATEGY_PARTITION
  # -- How to balance topic/partitions across bufstream nodes. One of: ["BALANCE_STRATEGY_UNSPECIFIED", "BALANCE_STRATEGY_PARTITION", "BALANCE_STRATEGY_HOST", "BALANCE_STRATEGY_CLIENT_ID"]
  partitionBalanceStrategy: BALANCE_STRATEGY_PARTITION
  # -- The number of kafka request to unmarshal and buffer before processing.
  requestBufferSize: 5
  # -- How long a Kafka connection can be idle before being closed by the server. If set a value less than or equal to zero, the timeout will be disabled.
  idleTimeout: 0
  # -- The default number of partitions to use for a new topic.
  numPartitions: 1
  # -- If exact log sizes should be fetched when listing sizes for all topics/partitions.
  exactLogSizes: true
  # -- If exact log hwm and start offsets should be computed when fetching records.
  exactLogOffsets: false
  # -- The default group consumer session timeout.
  groupConsumerSessionTimeout: 45s
  # -- The minimum group consumer session timeout.
  groupConsumerSessionTimeoutMin: 10s
  # -- The maximum group consumer session timeout.
  groupConsumerSessionTimeoutMax: 60s

# -- connectTLS contains TLS configuration for Control Server which is used for inter-agent communication using Connect protocol.
connectTLS:
  # -- Server contains server side TLS configuration.
  server: {}
    # server:
    #   # Kubernetes secrets containing a `tls.crt` and `tls.key` (as the secret keys, see https://kubernetes.io/docs/concepts/configuration/secret/#tls-secrets) to present to the client. The first certificate compatible with the client's requirements is selected automatically.
    #   certificateSecrets: []
  # -- Client contains client side TLS configuration to connect to the Control Server.
  client: {}
    # client:
    #   # Controls whether a client verifies the server's certificate chain and host name.
    #   insecureSkipVerify: true
    #   # The existing secret name that contains ca.crt key of the PEM-encoded root certificate authorities used by the client to validate
    #   # the server certificates.
    #   rootCaSecret: ""

# -- adminTLS contains TLS configuration for Admin Server.
adminTLS: {}
  # adminTLS:
  #   # Kubernetes secrets containing a `tls.crt` and `tls.key` (as the secret keys, see https://kubernetes.io/docs/concepts/configuration/secret/#tls-secrets) to present to the client. The first certificate compatible with the client's requirements is selected automatically.
  #   certificateSecrets: []

metadata:
  # -- Which metadata storage that bufstream is using.
  # Currently, only `etcd` is supported.
  use: etcd
  etcd:
    # -- Etcd addresses to connect to.
    addresses: []
    # addresses:
    # - host: ""
    #   port: 2379

    # -- TLS client configuration for bufstream to connect to etcd.
    tls: {}
    # tls:
    #   # Controls whether a client verifies the server's certificate chain and host name.
    #   insecureSkipVerify: true
    #   # The existing secret name that contains ca.crt key of the PEM-encoded root certificate authorities used by the client to validate
    #   # the server certificates.
    #   rootCaSecret: ""
storage:
  # -- Which object storage that bufstream is using.
  # Currently, `gcs` and `s3` are supported.
  use: s3
  gcs:
    # -- GCS bucket name.
    bucket: ""
    # -- GCS prefix to use for all stored files.
    prefix: ""
    # -- Kubernetes secret containing a `credentials.json` (as the secret key) service account key to use instead of the metadata server.
    secretName: ""
  s3:
    # -- S3 bucket name.
    bucket: ""
    # -- S3 bucket region.
    region: ""
    # -- S3 prefix to use for all stored files.
    prefix: ""
    # -- S3 Force Path Style setting. See https://docs.aws.amazon.com/sdk-for-java/latest/developer-guide/examples-s3.html.
    forcePathStyle: false
    # -- S3 Access Key ID to use instead of the metadata server.
    accessKeyId: ""
    # -- Kubernetes secret containing a `secret_access_key` (as the secret key) to use instead of the metadata server.
    secretName: ""
observability:
  # -- Log level to use.
  logLevel: INFO
  # -- Open Telemetry base endpoint to push metrics and traces to.
  # Deprecated: use exporter.address and exporter.insecure instead.
  otlpEndpoint: ""
  exporter:
    # -- Open Telemetry base endpoint to push metrics and traces. The value has a host and an optional port.
    # It should not include the URL path, such as "/v1/traces" or the scheme.
    # This can be overriden by metrics.address or tracing.address.
    address: ""
    # -- Whether to disable TLS for the exporter's HTTP connection.
    # This can be overriden by metrics.insecure or tracing.insecure.
    insecure: false
  metrics:
    # -- Open Telemetry exporter. Supports [NONE, STDOUT, HTTP, HTTPS, PROMETHEUS].
    # Deprecated: use exporterType instead.
    exporter: ""
    # -- Open Telemetry exporter. Supports [NONE, STDOUT, OTLP_GRPC, OTLP_HTTP, PROMETHEUS]
    exporterType: "NONE"
    # -- The endpoint the exporter connects to. The value has a host and an optional port.
    # It should not include the URL path, such as "/v1/metrics" or the scheme.
    # Specify path and insecure instead.
    address: ""
    # The URL path appended to address. Defaults to "/v1/metrics".
    # This can only be specified for the OTLP_HTTP exporter type.
    path: ""
    # -- Whether to disable TLS.
    # This can only be specified for OTLP_HTTP exporter type.
    insecure: false
    # This omits metrics that depend on the kafka.topic.partition attribute, which may have high cardinality
    # depending on the configuration. One example is kafka.topic.partition.offset.high_water_mark.
    # This omits only the attribute for metrics that have this attribute without depending on it.
    # One example is kafka.produce.record.size.
    # Deprecated: set aggregation.partitions to true instead.
    # @ignored
    omitPartitionAttribute: false
    # Whether to emit bufstream.internal.* metrics.
    # @ignored
    enableInternalMetrics: false
    # Allows changing the default temporality preference for OTLP metrics.
    # This is recommended to be set to "delta" for reporting to Datadog agents.
    # See https://docs.datadoghq.com/opentelemetry/guide/otlp_delta_temporality/ for more details.
    otlpTemporalityPreference: ""
    # This option, typically set to reduce cardinality, aggregates some metrics over certain attributes, such as kafka.topic.name.
    aggregation:
      # Aggregate metrics across all topics to avoid cardinality issues with clusters with a large number of topics.
      # Metrics that support this aggregation will report the 'kafka.topic.name' attribute as '_all_topics_'.
      # NOTE: This implies partitions aggregation, which omits metrics like 'bufstream.kafka.topic.partition.offset.high_water_mark'.
      topics: false
      # Aggregate metrics across all parttions to avoid cardinality issues with clusters with a large number of partitions.
      # Metrics that support aggregation will report the 'kafka.partition.id' attribute as -1, while some metrics, such as
      # 'bufstream.kafka.topic.partition.offset.high_water_mark' will be omitted if partition level aggregation is enabled.
      partitions: false
      # Aggregate metrics across all consumer groups to avoid cardinality issues with clusters with a large number of groups.
      # Metrics that support aggregation will report the 'kafka.consumer.group.id' as '_all_groups_', while some metrics
      # such as 'bufstream.kafka.consumer.group.generation' will be omitted if consumer group level aggregation is enabled.
      consumerGroups: false
  tracing:
    # -- Open Telemetry exporter. Supports [NONE, STDOUT, HTTP, HTTPS].
    # Deprecated: use exporterType instead.
    exporter: ""
    # -- Open Telemetry exporter. Supports [NONE, STDOUT, OTLP_GRPC, OTLP_HTTP]
    exporterType: "NONE"
    # -- The endpoint the exporter connects to. The value has a host and an optional port.
    # It should not include the URL path, such as "/v1/traces" or the scheme.
    # Specify path and insecure instead.
    address: ""
    # The URL path appended to address. Defaults to "/v1/traces".
    # This can only be specified for the OTLP_HTTP or OTLP_GRPC exporter type.
    path: ""
    # -- Whether to disable TLS.
    # This can only be specified for OTLP_HTTP exporter type.
    insecure: false
    # -- Trace sample ratio.
    traceRatio: 0.1
  # -- Redact sensitive information such as topic names, before adding to to metrics, traces and logs.
  # Supports [NONE, OPAQUE]
  sensitiveInformationRedaction: "NONE"
bufstream:
  service:
    # -- Whether to create a Kubernetes Service for this bufstream deployment.
    enabled: true
    # -- Kubernetes Service type.
    type: ClusterIP
    # -- Kubernetes Service annotations.
    annotations: {}
  serviceAccount:
    # -- Whether to create a Kubernetes Service Account for this bufstream deployment.
    create: true
    # -- Kubernetes Service Account name.
    name: bufstream-service-account
    # -- Kubernetes Service Account annotations.
    annotations: {}
  deployment:
    # -- Bufstream Deployment kind.
    # Supports [Deployment, StatefulSet]
    kind: StatefulSet
    # -- Bufstream Deployment command.
    # @default -- `["/usr/local/bin/bufstream"]`
    command: []
    # -- Bufstream Deployment args to be appended.
    args: []
    # -- Bufstream Deployment replica count.
    replicaCount: 3
    # -- Bufstream Deployment Pod annotations.
    podAnnotations: {}
    # -- Bufstream Deployment Selector labels.
    selectorLabels: {}
    # -- Bufstream Deployment Pod labels.
    podLabels: {}
    # -- Bufstream Deployment pod management policy to use when StatefulSet kind is used.
    podManagementPolicy: Parallel
    # -- Bufstream Deployment service name to link for per pod DNS registration when StatefulSet kind is used.
    serviceName: ""

    resources:
      requests:
        # -- Bufstream Deployment Resource request CPU.
        cpu: 2
        # -- Bufstream Deployment Resource request memory.
        memory: 8Gi
      limits:
        # -- Bufstream Deployment Resource request CPU.
        cpu: ""
        # -- Bufstream Deployment Resource limits memory.
        memory: 8Gi
    # -- Bufstream Deployment Node selector.
    nodeSelector: {}
    # -- Bufstream Deployment Affinity.
    affinity: {}
    # -- Bufstream Deployment Tolerations.
    tolerations: []
    # -- Bufstream Deployment Extra environment variables for the bufstream container.
    extraEnv: []
    # -- Bufstream Deployment Extra volume mounts for the bufstream container.
    extraVolumeMounts: []
    # -- Bufstream Deployment Extra volumes.
    extraVolumes: []
    # -- Bufstream Deployment Extra container ports for the bufstream container.
    extraContainerPorts: {}
    # -- Bufstream Deployment additional containers to run besides the bufstream container.
    extraContainers: []
    livenessProbe:
      # -- Bufstream Deployment Liveness Probe Maximum failure threshold.
      failureThreshold: 3
      # -- Bufstream Deployment Liveness Probe timeout.
      timeoutSeconds: 5
    readinessProbe:
      # -- Bufstream Deployment Readiness Probe Maximum failure threshold.
      failureThreshold: 3
      # -- Bufstream Deployment Readiness Probe timeout.
      timeoutSeconds: 5
    startupProbe:
      # -- Bufstream Deployment Liveness Probe Configuration
      failureThreshold: 3
    # -- Bufstream Deployment termination grace period.
    terminationGracePeriodSeconds: 420 # 7 minutes
    # -- Bufstream Deployment setting for sharing the process namespace.
    shareProcessNamespace: false
    autoscaling:
      # -- Whether to enable the horizontal pod autoscaler.
      enabled: false
      # -- Minimum number of autoscaler allowed replicas.
      minReplicas: 6
      # -- Maximum number of autoscaler allowed replicas.
      maxReplicas: 18
      # -- Target CPU threshold for managing replica count.
      targetCPU: "50"
      # -- Target memory threshold for managing replica count.
      targetMemory: ""
      # -- [Horizontal Pod Autoscaler behavior.](https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#configurable-scaling-behavior)
      behavior: {}
  controlServerService:
    # -- Whether to create a Kubernetes Headless Service for the Bufstream Control Server (inter-agent RPC server using the Connect protocol).
    enabled: false
    # -- Kubernetes Service annotations.
    annotations: {}
  podDisruptionBudget:
    # -- Whether to enable pod disruption budget.
    enabled: false
    # -- Number of pods that are available after eviction as number or percentage (eg.: 50%).
    # @default -- `""` (defaults to 0 if not specified)
    minAvailable: ""
    # -- Number of pods that are unavailable after eviction as number or percentage (eg.: 50%). Has higher precedence over `minAvailable`
    maxUnavailable: ""
  image:
    # -- Bufstream Deployment container image repository.
    repository: us-docker.pkg.dev/buf-images-1/bufstream-public/images/bufstream
    # -- Overrides the image tag whose default is the chart version.
    tag: "latest"
    # -- Bufstream Deployment container image pull policy.
    pullPolicy: IfNotPresent
# -- Extra Kubernetes objects to install as part of this chart.
extraObjects: []
# -- Bufstream configuration overrides. Any value here will be set directly on the bufstream config.yaml, taking precedence over any other helm defined values.
configOverrides: {}

To configure Bufstream with recommended, cloud-specific settings, consult the AWS and GCP documentation.