Skip to main content

Advanced parameters for Aiven for Apache Kafka®

See the configuration options available for Aiven for Apache Kafka®:

Parameter

custom_domain

string,null

Custom domain

Serve the web frontend using a custom CNAME pointing to the Aiven DNS name

ip_filter

array

  • default: 0.0.0.0/0

IP filter

Allow incoming connections from CIDR address block, e.g. '10.20.0.0/16'

service_log

boolean,null

Service logging

Store logs for the service so that they are available in the HTTP API and console.

static_ips

boolean

Static IP addresses

Use static public IP addresses

private_access

object

Allow access to selected service ports from private networks

private_access.kafka

boolean

Allow clients to connect to kafka with a DNS name that always resolves to the service's private IP addresses. Only available in certain network locations

private_access.kafka_connect

boolean

Allow clients to connect to kafka_connect with a DNS name that always resolves to the service's private IP addresses. Only available in certain network locations

private_access.kafka_rest

boolean

Allow clients to connect to kafka_rest with a DNS name that always resolves to the service's private IP addresses. Only available in certain network locations

private_access.prometheus

boolean

Allow clients to connect to prometheus with a DNS name that always resolves to the service's private IP addresses. Only available in certain network locations

private_access.schema_registry

boolean

Allow clients to connect to schema_registry with a DNS name that always resolves to the service's private IP addresses. Only available in certain network locations

public_access

object

Allow access to selected service ports from the public Internet

public_access.kafka

boolean

Allow clients to connect to kafka from the public internet for service nodes that are in a project VPC or another type of private network

public_access.kafka_connect

boolean

Allow clients to connect to kafka_connect from the public internet for service nodes that are in a project VPC or another type of private network

public_access.kafka_rest

boolean

Allow clients to connect to kafka_rest from the public internet for service nodes that are in a project VPC or another type of private network

public_access.prometheus

boolean

Allow clients to connect to prometheus from the public internet for service nodes that are in a project VPC or another type of private network

public_access.schema_registry

boolean

Allow clients to connect to schema_registry from the public internet for service nodes that are in a project VPC or another type of private network

privatelink_access

object

Allow access to selected service components through Privatelink

privatelink_access.jolokia

boolean

Enable jolokia

privatelink_access.kafka

boolean

Enable kafka

privatelink_access.kafka_connect

boolean

Enable kafka_connect

privatelink_access.kafka_rest

boolean

Enable kafka_rest

privatelink_access.prometheus

boolean

Enable prometheus

privatelink_access.schema_registry

boolean

Enable schema_registry

letsencrypt_sasl_privatelink

boolean,null

Use Letsencrypt CA for Kafka SASL via Privatelink

Use Letsencrypt CA for Kafka SASL via Privatelink

kafka

object

  • default: [object Object]

Kafka broker configuration values

kafka.compression_type

string

compression.type

Specify the final compression type for a given topic. This configuration accepts the standard compression codecs ('gzip', 'snappy', 'lz4', 'zstd'). It additionally accepts 'uncompressed' which is equivalent to no compression; and 'producer' which means retain the original compression codec set by the producer.(Default: producer)

kafka.group_initial_rebalance_delay_ms

integer

  • max: 300000

group.initial.rebalance.delay.ms

The amount of time, in milliseconds, the group coordinator will wait for more consumers to join a new group before performing the first rebalance. A longer delay means potentially fewer rebalances, but increases the time until processing begins. The default value for this is 3 seconds. During development and testing it might be desirable to set this to 0 in order to not delay test execution time. (Default: 3000 ms (3 seconds))

kafka.group_min_session_timeout_ms

integer

  • max: 60000

group.min.session.timeout.ms

The minimum allowed session timeout for registered consumers. Longer timeouts give consumers more time to process messages in between heartbeats at the cost of a longer time to detect failures. (Default: 6000 ms (6 seconds))

kafka.group_max_session_timeout_ms

integer

  • max: 1800000

group.max.session.timeout.ms

The maximum allowed session timeout for registered consumers. Longer timeouts give consumers more time to process messages in between heartbeats at the cost of a longer time to detect failures. Default: 1800000 ms (30 minutes)

kafka.connections_max_idle_ms

integer

  • min: 1000
  • max: 3600000

connections.max.idle.ms

Idle connections timeout: the server socket processor threads close the connections that idle for longer than this. (Default: 600000 ms (10 minutes))

kafka.max_incremental_fetch_session_cache_slots

integer

  • min: 1000
  • max: 10000

max.incremental.fetch.session.cache.slots

The maximum number of incremental fetch sessions that the broker will maintain. (Default: 1000)

kafka.message_max_bytes

integer

  • max: 100001200

message.max.bytes

The maximum size of message that the server can receive. (Default: 1048588 bytes (1 mebibyte + 12 bytes))

kafka.offsets_retention_minutes

integer

  • min: 1
  • max: 2147483647

offsets.retention.minutes

Log retention window in minutes for offsets topic (Default: 10080 minutes (7 days))

kafka.log_cleaner_delete_retention_ms

integer

  • max: 315569260000

log.cleaner.delete.retention.ms

How long are delete records retained? (Default: 86400000 (1 day))

kafka.log_cleaner_min_cleanable_ratio

number

  • min: 0.2
  • max: 0.9

log.cleaner.min.cleanable.ratio

Controls log compactor frequency. Larger value means more frequent compactions but also more space wasted for logs. Consider setting log.cleaner.max.compaction.lag.ms to enforce compactions sooner, instead of setting a very high value for this option. (Default: 0.5)

kafka.log_cleaner_max_compaction_lag_ms

integer

  • min: 30000
  • max: 9223372036854776000

log.cleaner.max.compaction.lag.ms

The maximum amount of time message will remain uncompacted. Only applicable for logs that are being compacted. (Default: 9223372036854775807 ms (Long.MAX_VALUE))

kafka.log_cleaner_min_compaction_lag_ms

integer

  • max: 9223372036854776000

log.cleaner.min.compaction.lag.ms

The minimum time a message will remain uncompacted in the log. Only applicable for logs that are being compacted. (Default: 0 ms)

kafka.log_cleanup_policy

string

log.cleanup.policy

The default cleanup policy for segments beyond the retention window (Default: delete)

kafka.log_flush_interval_messages

integer

  • min: 1
  • max: 9223372036854776000

log.flush.interval.messages

The number of messages accumulated on a log partition before messages are flushed to disk (Default: 9223372036854775807 (Long.MAX_VALUE))

kafka.log_flush_interval_ms

integer

  • max: 9223372036854776000

log.flush.interval.ms

The maximum time in ms that a message in any topic is kept in memory (page-cache) before flushed to disk. If not set, the value in log.flush.scheduler.interval.ms is used (Default: null)

kafka.log_index_interval_bytes

integer

  • max: 104857600

log.index.interval.bytes

The interval with which Kafka adds an entry to the offset index (Default: 4096 bytes (4 kibibytes))

kafka.log_index_size_max_bytes

integer

  • min: 1048576
  • max: 104857600

log.index.size.max.bytes

The maximum size in bytes of the offset index (Default: 10485760 (10 mebibytes))

kafka.log_local_retention_ms

integer

  • min: -2
  • max: 9223372036854776000

log.local.retention.ms

The number of milliseconds to keep the local log segments before it gets eligible for deletion. If set to -2, the value of log.retention.ms is used. The effective value should always be less than or equal to log.retention.ms value. (Default: -2)

kafka.log_local_retention_bytes

integer

  • min: -2
  • max: 9223372036854776000

log.local.retention.bytes

The maximum size of local log segments that can grow for a partition before it gets eligible for deletion. If set to -2, the value of log.retention.bytes is used. The effective value should always be less than or equal to log.retention.bytes value. (Default: -2)

kafka.log_message_downconversion_enable

boolean

log.message.downconversion.enable

This configuration controls whether down-conversion of message formats is enabled to satisfy consume requests. (Default: true)

kafka.log_message_timestamp_type

string

log.message.timestamp.type

Define whether the timestamp in the message is message create time or log append time. (Default: CreateTime)

kafka.log_message_timestamp_difference_max_ms

integer

  • max: 9223372036854776000

log.message.timestamp.difference.max.ms

The maximum difference allowed between the timestamp when a broker receives a message and the timestamp specified in the message (Default: 9223372036854775807 (Long.MAX_VALUE))

kafka.log_preallocate

boolean

log.preallocate

Should pre allocate file when create new segment? (Default: false)

kafka.log_retention_bytes

integer

  • min: -1
  • max: 9223372036854776000

log.retention.bytes

The maximum size of the log before deleting messages (Default: -1)

kafka.log_retention_hours

integer

  • min: -1
  • max: 2147483647

log.retention.hours

The number of hours to keep a log file before deleting it (Default: 168 hours (1 week))

kafka.log_retention_ms

integer

  • min: -1
  • max: 9223372036854776000

log.retention.ms

The number of milliseconds to keep a log file before deleting it (in milliseconds), If not set, the value in log.retention.minutes is used. If set to -1, no time limit is applied. (Default: null, log.retention.hours applies)

kafka.log_roll_jitter_ms

integer

  • max: 9223372036854776000

log.roll.jitter.ms

The maximum jitter to subtract from logRollTimeMillis (in milliseconds). If not set, the value in log.roll.jitter.hours is used (Default: null)

kafka.log_roll_ms

integer

  • min: 1
  • max: 9223372036854776000

log.roll.ms

The maximum time before a new log segment is rolled out (in milliseconds). (Default: null, log.roll.hours applies (Default: 168, 7 days))

kafka.log_segment_bytes

integer

  • min: 10485760
  • max: 1073741824

log.segment.bytes

The maximum size of a single log file (Default: 1073741824 bytes (1 gibibyte))

kafka.log_segment_delete_delay_ms

integer

  • max: 3600000

log.segment.delete.delay.ms

The amount of time to wait before deleting a file from the filesystem (Default: 60000 ms (1 minute))

kafka.auto_create_topics_enable

boolean

auto.create.topics.enable

Enable auto-creation of topics. (Default: true)

kafka.min_insync_replicas

integer

  • min: 1
  • max: 7

min.insync.replicas

When a producer sets acks to 'all' (or '-1'), min.insync.replicas specifies the minimum number of replicas that must acknowledge a write for the write to be considered successful. (Default: 1)

kafka.num_partitions

integer

  • min: 1
  • max: 1000

num.partitions

Number of partitions for auto-created topics (Default: 1)

kafka.default_replication_factor

integer

  • min: 1
  • max: 10

default.replication.factor

Replication factor for auto-created topics (Default: 3)

kafka.replica_fetch_max_bytes

integer

  • min: 1048576
  • max: 104857600

replica.fetch.max.bytes

The number of bytes of messages to attempt to fetch for each partition . This is not an absolute maximum, if the first record batch in the first non-empty partition of the fetch is larger than this value, the record batch will still be returned to ensure that progress can be made. (Default: 1048576 bytes (1 mebibytes))

kafka.replica_fetch_response_max_bytes

integer

  • min: 10485760
  • max: 1048576000

replica.fetch.response.max.bytes

Maximum bytes expected for the entire fetch response. Records are fetched in batches, and if the first record batch in the first non-empty partition of the fetch is larger than this value, the record batch will still be returned to ensure that progress can be made. As such, this is not an absolute maximum. (Default: 10485760 bytes (10 mebibytes))

kafka.max_connections_per_ip

integer

  • min: 256
  • max: 2147483647

max.connections.per.ip

The maximum number of connections allowed from each ip address (Default: 2147483647).

kafka.producer_purgatory_purge_interval_requests

integer

  • min: 10
  • max: 10000

producer.purgatory.purge.interval.requests

The purge interval (in number of requests) of the producer request purgatory (Default: 1000).

kafka.sasl_oauthbearer_expected_audience

string

sasl.oauthbearer.expected.audience

The (optional) comma-delimited setting for the broker to use to verify that the JWT was issued for one of the expected audiences. (Default: null)

kafka.sasl_oauthbearer_expected_issuer

string

sasl.oauthbearer.expected.issuer

Optional setting for the broker to use to verify that the JWT was created by the expected issuer.(Default: null)

kafka.sasl_oauthbearer_jwks_endpoint_url

string

sasl.oauthbearer.jwks.endpoint.url

OIDC JWKS endpoint URL. By setting this the SASL SSL OAuth2/OIDC authentication is enabled. See also other options for SASL OAuth2/OIDC. (Default: null)

kafka.sasl_oauthbearer_sub_claim_name

string

sasl.oauthbearer.sub.claim.name

Name of the scope from which to extract the subject claim from the JWT.(Default: sub)

kafka.socket_request_max_bytes

integer

  • min: 10485760
  • max: 209715200

socket.request.max.bytes

The maximum number of bytes in a socket request (Default: 104857600 bytes).

kafka.transaction_state_log_segment_bytes

integer

  • min: 1048576
  • max: 2147483647

transaction.state.log.segment.bytes

The transaction topic segment bytes should be kept relatively small in order to facilitate faster log compaction and cache loads (Default: 104857600 bytes (100 mebibytes)).

kafka.transaction_remove_expired_transaction_cleanup_interval_ms

integer

  • min: 600000
  • max: 3600000

transaction.remove.expired.transaction.cleanup.interval.ms

The interval at which to remove transactions that have expired due to transactional.id.expiration.ms passing (Default: 3600000 ms (1 hour)).

kafka.transaction_partition_verification_enable

boolean

transaction.partition.verification.enable

Enable verification that checks that the partition has been added to the transaction before writing transactional records to the partition. (Default: true)

kafka_authentication_methods

object

Kafka authentication methods

kafka_authentication_methods.certificate

boolean

  • default: true

Enable certificate/SSL authentication

kafka_authentication_methods.sasl

boolean

Enable SASL authentication

kafka_sasl_mechanisms

object

Kafka SASL mechanisms

kafka_sasl_mechanisms.plain

boolean

  • default: true

Enable PLAIN mechanism

kafka_sasl_mechanisms.scram_sha_256

boolean

  • default: true

Enable SCRAM-SHA-256 mechanism

kafka_sasl_mechanisms.scram_sha_512

boolean

  • default: true

Enable SCRAM-SHA-512 mechanism

follower_fetching

object

Enable follower fetching

follower_fetching.enabled

boolean

Enabled

Whether to enable the follower fetching functionality

kafka_connect

boolean

Enable Kafka Connect service

kafka_connect_config

object

Kafka Connect configuration values

kafka_connect_config.connector_client_config_override_policy

string

Client config override policy

Defines what client configurations can be overridden by the connector. Default is None

kafka_connect_config.consumer_auto_offset_reset

string

Consumer auto offset reset

What to do when there is no initial offset in Kafka or if the current offset does not exist any more on the server. Default is earliest

kafka_connect_config.consumer_fetch_max_bytes

integer

  • min: 1048576
  • max: 104857600

The maximum amount of data the server should return for a fetch request

Records are fetched in batches by the consumer, and if the first record batch in the first non-empty partition of the fetch is larger than this value, the record batch will still be returned to ensure that the consumer can make progress. As such, this is not a absolute maximum.

kafka_connect_config.consumer_isolation_level

string

Consumer isolation level

Transaction read isolation level. read_uncommitted is the default, but read_committed can be used if consume-exactly-once behavior is desired.

kafka_connect_config.consumer_max_partition_fetch_bytes

integer

  • min: 1048576
  • max: 104857600

The maximum amount of data per-partition the server will return.

Records are fetched in batches by the consumer.If the first record batch in the first non-empty partition of the fetch is larger than this limit, the batch will still be returned to ensure that the consumer can make progress.

kafka_connect_config.consumer_max_poll_interval_ms

integer

  • min: 1
  • max: 2147483647

The maximum delay between polls when using consumer group management

The maximum delay in milliseconds between invocations of poll() when using consumer group management (defaults to 300000).

kafka_connect_config.consumer_max_poll_records

integer

  • min: 1
  • max: 10000

The maximum number of records returned by a single poll

The maximum number of records returned in a single call to poll() (defaults to 500).

kafka_connect_config.offset_flush_interval_ms

integer

  • min: 1
  • max: 100000000

The interval at which to try committing offsets for tasks

The interval at which to try committing offsets for tasks (defaults to 60000).

kafka_connect_config.offset_flush_timeout_ms

integer

  • min: 1
  • max: 2147483647

Offset flush timeout

Maximum number of milliseconds to wait for records to flush and partition offset data to be committed to offset storage before cancelling the process and restoring the offset data to be committed in a future attempt (defaults to 5000).

kafka_connect_config.producer_batch_size

integer

  • max: 5242880

The batch size in bytes the producer will attempt to collect for the same partition before publishing to broker

This setting gives the upper bound of the batch size to be sent. If there are fewer than this many bytes accumulated for this partition, the producer will 'linger' for the linger.ms time waiting for more records to show up. A batch size of zero will disable batching entirely (defaults to 16384).

kafka_connect_config.producer_buffer_memory

integer

  • min: 5242880
  • max: 134217728

The total bytes of memory the producer can use to buffer records waiting to be sent to the broker

The total bytes of memory the producer can use to buffer records waiting to be sent to the broker (defaults to 33554432).

kafka_connect_config.producer_compression_type

string

The default compression type for producers

Specify the default compression type for producers. This configuration accepts the standard compression codecs ('gzip', 'snappy', 'lz4', 'zstd'). It additionally accepts 'none' which is the default and equivalent to no compression.

kafka_connect_config.producer_linger_ms

integer

  • max: 5000

Wait for up to the given delay to allow batching records together

This setting gives the upper bound on the delay for batching: once there is batch.size worth of records for a partition it will be sent immediately regardless of this setting, however if there are fewer than this many bytes accumulated for this partition the producer will 'linger' for the specified time waiting for more records to show up. Defaults to 0.

kafka_connect_config.producer_max_request_size

integer

  • min: 131072
  • max: 67108864

The maximum size of a request in bytes

This setting will limit the number of record batches the producer will send in a single request to avoid sending huge requests.

kafka_connect_config.scheduled_rebalance_max_delay_ms

integer

  • max: 600000

The maximum delay of rebalancing connector workers

The maximum delay that is scheduled in order to wait for the return of one or more departed workers before rebalancing and reassigning their connectors and tasks to the group. During this period the connectors and tasks of the departed workers remain unassigned. Defaults to 5 minutes.

kafka_connect_config.session_timeout_ms

integer

  • min: 1
  • max: 2147483647

The timeout used to detect failures when using Kafka’s group management facilities

The timeout in milliseconds used to detect failures when using Kafka’s group management facilities (defaults to 10000).

kafka_connect_secret_providers

array

Kafka Connect secret providers

Configure external secret providers in order to reference external secrets in connector configuration. Currently Hashicorp Vault (provider: vault, auth_method: token) and AWS Secrets Manager (provider: aws, auth_method: credentials) are supported. Secrets can be referenced in connector config with ${<provider_name>:<secret_path>:<key_name>}

kafka_rest

boolean

Enable Kafka-REST service

kafka_version

string,null

Kafka major version

schema_registry

boolean

Enable Schema-Registry service

kafka_rest_authorization

boolean

Enable authorization in Kafka-REST service

kafka_rest_config

object

Kafka REST configuration

kafka_rest_config.producer_acks

string

  • default: 1

producer.acks

The number of acknowledgments the producer requires the leader to have received before considering a request complete. If set to 'all' or '-1', the leader will wait for the full set of in-sync replicas to acknowledge the record.

kafka_rest_config.producer_compression_type

string

producer.compression.type

Specify the default compression type for producers. This configuration accepts the standard compression codecs ('gzip', 'snappy', 'lz4', 'zstd'). It additionally accepts 'none' which is the default and equivalent to no compression.

kafka_rest_config.producer_linger_ms

integer

  • max: 5000

producer.linger.ms

Wait for up to the given delay to allow batching records together

kafka_rest_config.producer_max_request_size

integer

  • max: 2147483647
  • default: 1048576

producer.max.request.size

The maximum size of a request in bytes. Note that Kafka broker can also cap the record batch size.

kafka_rest_config.consumer_enable_auto_commit

boolean

  • default: true

consumer.enable.auto.commit

If true the consumer's offset will be periodically committed to Kafka in the background

kafka_rest_config.consumer_request_max_bytes

integer

  • max: 671088640
  • default: 67108864

consumer.request.max.bytes

Maximum number of bytes in unencoded message keys and values by a single request

kafka_rest_config.consumer_request_timeout_ms

integer

  • min: 1000
  • max: 30000
  • default: 1000

consumer.request.timeout.ms

The maximum total time to wait for messages for a request if the maximum number of messages has not yet been reached

kafka_rest_config.name_strategy

string

  • default: topic_name

name.strategy

Name strategy to use when selecting subject for storing schemas

kafka_rest_config.name_strategy_validation

boolean

  • default: true

name.strategy.validation

If true, validate that given schema is registered under expected subject name by the used name strategy when producing messages.

kafka_rest_config.simpleconsumer_pool_size_max

integer

  • min: 10
  • max: 250
  • default: 25

simpleconsumer.pool.size.max

Maximum number of SimpleConsumers that can be instantiated per broker

tiered_storage

object

Tiered storage configuration

tiered_storage.enabled

boolean

Enabled

Whether to enable the tiered storage functionality

schema_registry_config

object

Schema Registry configuration

schema_registry_config.topic_name

string

topic_name

The durable single partition topic that acts as the durable log for the data. This topic must be compacted to avoid losing data due to retention policy. Please note that changing this configuration in an existing Schema Registry / Karapace setup leads to previous schemas being inaccessible, data encoded with them potentially unreadable and schema ID sequence put out of order. It's only possible to do the switch while Schema Registry / Karapace is disabled. Defaults to _schemas.

schema_registry_config.leader_eligibility

boolean

leader_eligibility

If true, Karapace / Schema Registry on the service nodes can participate in leader election. It might be needed to disable this when the schemas topic is replicated to a secondary cluster and Karapace / Schema Registry there must not participate in leader election. Defaults to true.

aiven_kafka_topic_messages

boolean

Allow access to read Kafka topic messages in the Aiven Console and REST API.