org.apache.camel.component.kafka.KafkaConfiguration Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.component.kafka;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.ExecutorService;
import java.util.stream.Collectors;
import org.apache.camel.Exchange;
import org.apache.camel.RuntimeCamelException;
import org.apache.camel.component.kafka.consumer.KafkaManualCommit;
import org.apache.camel.component.kafka.serde.DefaultKafkaHeaderDeserializer;
import org.apache.camel.component.kafka.serde.DefaultKafkaHeaderSerializer;
import org.apache.camel.component.kafka.serde.KafkaHeaderDeserializer;
import org.apache.camel.component.kafka.serde.KafkaHeaderSerializer;
import org.apache.camel.spi.HeaderFilterStrategy;
import org.apache.camel.spi.HeaderFilterStrategyAware;
import org.apache.camel.spi.Metadata;
import org.apache.camel.spi.StateRepository;
import org.apache.camel.spi.UriParam;
import org.apache.camel.spi.UriParams;
import org.apache.camel.spi.UriPath;
import org.apache.camel.support.ResourceHelper;
import org.apache.camel.support.jsse.CipherSuitesParameters;
import org.apache.camel.support.jsse.KeyManagersParameters;
import org.apache.camel.support.jsse.KeyStoreParameters;
import org.apache.camel.support.jsse.SSLContextParameters;
import org.apache.camel.support.jsse.SecureSocketProtocolsParameters;
import org.apache.camel.support.jsse.TrustManagersParameters;
import org.apache.camel.util.ObjectHelper;
import org.apache.camel.util.StringHelper;
import org.apache.kafka.clients.CommonClientConfigs;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.clients.producer.RecordMetadata;
import org.apache.kafka.common.config.SaslConfigs;
import org.apache.kafka.common.config.SslConfigs;
import org.apache.kafka.common.config.internals.BrokerSecurityConfigs;
import org.apache.kafka.common.security.auth.SecurityProtocol;
@UriParams
public class KafkaConfiguration implements Cloneable, HeaderFilterStrategyAware {
// Common configuration properties
@UriPath(label = "common")
@Metadata(required = true)
private String topic;
@UriParam(label = "common")
private String brokers;
@UriParam(label = "common")
private String clientId;
@UriParam(label = "common",
description = "To use a custom HeaderFilterStrategy to filter header to and from Camel message.")
private HeaderFilterStrategy headerFilterStrategy = new KafkaHeaderFilterStrategy();
@UriParam(label = "common", defaultValue = "100")
private Integer retryBackoffMs = 100;
@UriParam(label = "common", defaultValue = "1000")
private Integer retryBackoffMaxMs = 1000;
@UriParam(label = "consumer", defaultValue = "true")
private boolean preValidateHostAndPort = true;
@UriParam(label = "consumer")
private boolean topicIsPattern;
@UriParam(label = "consumer")
private String groupId;
@UriParam(label = "consumer")
private String groupInstanceId;
@UriParam(label = "consumer", defaultValue = "1")
private int consumersCount = 1;
@UriParam(label = "consumer", description = "To use a custom KafkaHeaderDeserializer to deserialize kafka headers values")
private KafkaHeaderDeserializer headerDeserializer = new DefaultKafkaHeaderDeserializer();
// interceptor.classes
@UriParam(label = "common,monitoring")
private String interceptorClasses;
// key.deserializer
@UriParam(label = "consumer", defaultValue = KafkaConstants.KAFKA_DEFAULT_DESERIALIZER)
private String keyDeserializer = KafkaConstants.KAFKA_DEFAULT_DESERIALIZER;
// value.deserializer
@UriParam(label = "consumer", defaultValue = KafkaConstants.KAFKA_DEFAULT_DESERIALIZER)
private String valueDeserializer = KafkaConstants.KAFKA_DEFAULT_DESERIALIZER;
// fetch.min.bytes
@UriParam(label = "consumer", defaultValue = "1")
private Integer fetchMinBytes = 1;
// fetch.min.bytes
@UriParam(label = "consumer", defaultValue = "52428800")
private Integer fetchMaxBytes = 50 * 1024 * 1024;
// heartbeat.interval.ms
@UriParam(label = "consumer", defaultValue = "3000")
private Integer heartbeatIntervalMs = 3000;
// max.partition.fetch.bytes
@UriParam(label = "consumer", defaultValue = "1048576")
private Integer maxPartitionFetchBytes = 1048576;
// session.timeout.ms
@UriParam(label = "consumer", defaultValue = "45000")
private Integer sessionTimeoutMs = 45000;
@UriParam(label = "consumer", defaultValue = "500")
private Integer maxPollRecords;
@UriParam(label = "consumer", defaultValue = "5000", javaType = "java.time.Duration")
private Long pollTimeoutMs = 5000L;
@UriParam(label = "consumer", javaType = "java.time.Duration")
private Integer maxPollIntervalMs;
// auto.offset.reset1
@UriParam(label = "consumer", defaultValue = "latest", enums = "latest,earliest,none")
private String autoOffsetReset = "latest";
// partition.assignment.strategy
@UriParam(label = "consumer", defaultValue = KafkaConstants.PARTITIONER_RANGE_ASSIGNOR)
private String partitionAssignor = KafkaConstants.PARTITIONER_RANGE_ASSIGNOR;
// request.timeout.ms
@UriParam(label = "consumer", defaultValue = "30000")
private Integer consumerRequestTimeoutMs = 30000;
// auto.commit.interval.ms
@UriParam(label = "consumer", defaultValue = "5000")
private Integer autoCommitIntervalMs = 5000;
// check.crcs
@UriParam(label = "consumer", defaultValue = "true")
private Boolean checkCrcs = true;
// fetch.max.wait.ms
@UriParam(label = "consumer", defaultValue = "500")
private Integer fetchWaitMaxMs = 500;
@UriParam(label = "consumer")
private SeekPolicy seekTo;
// Consumer configuration properties
@UriParam(label = "consumer", defaultValue = "true")
private boolean autoCommitEnable = true;
@UriParam(label = "consumer")
private boolean allowManualCommit;
@UriParam(label = "consumer")
private boolean breakOnFirstError;
@UriParam(label = "consumer")
private StateRepository offsetRepository;
@UriParam(label = "consumer", defaultValue = "ERROR_HANDLER")
private PollOnError pollOnError = PollOnError.ERROR_HANDLER;
@UriParam(label = "consumer", defaultValue = "5000", javaType = "java.time.Duration")
private Long commitTimeoutMs = 5000L;
@UriParam(label = "consumer,advanced", defaultValue = "read_uncommitted", enums = "read_uncommitted,read_committed")
private String isolationLevel;
// Producer configuration properties
@UriParam(label = "producer")
private String partitioner;
@UriParam(label = "producer", defaultValue = "false")
private boolean partitionerIgnoreKeys;
@UriParam(label = "producer")
private ExecutorService workerPool;
@UriParam(label = "producer", defaultValue = "10")
private Integer workerPoolCoreSize = 10;
@UriParam(label = "producer", defaultValue = "20")
private Integer workerPoolMaxSize = 20;
// Async producer config
@UriParam(label = "producer", defaultValue = "10000")
private Integer queueBufferingMaxMessages = 10000;
@UriParam(label = "producer", defaultValue = KafkaConstants.KAFKA_DEFAULT_SERIALIZER)
private String valueSerializer = KafkaConstants.KAFKA_DEFAULT_SERIALIZER;
@UriParam(label = "producer", defaultValue = KafkaConstants.KAFKA_DEFAULT_SERIALIZER)
private String keySerializer = KafkaConstants.KAFKA_DEFAULT_SERIALIZER;
@UriParam(label = "producer")
private String key;
@UriParam(label = "producer")
private Integer partitionKey;
@UriParam(label = "producer", defaultValue = "true")
private boolean useIterator = true;
@UriParam(label = "producer", enums = "all,-1,0,1", defaultValue = "all")
private String requestRequiredAcks = "all";
// buffer.memory
@UriParam(label = "producer", defaultValue = "33554432")
private Integer bufferMemorySize = 33554432;
// compression.type
@UriParam(label = "producer", defaultValue = "none", enums = "none,gzip,snappy,lz4,zstd")
private String compressionCodec = "none";
// retries
@UriParam(label = "producer")
private Integer retries;
// use individual headers if exchange.body contains Iterable or similar of Message or Exchange
@UriParam(label = "producer", defaultValue = "false")
private boolean batchWithIndividualHeaders;
// batch.size
@UriParam(label = "producer", defaultValue = "16384")
private Integer producerBatchSize = 16384;
// connections.max.idle.ms
@UriParam(label = "producer", defaultValue = "540000")
private Integer connectionMaxIdleMs = 540000;
// linger.ms
@UriParam(label = "producer", defaultValue = "0")
private Integer lingerMs = 0;
// linger.ms
@UriParam(label = "producer", defaultValue = "60000")
private Integer maxBlockMs = 60000;
// max.request.size
@UriParam(label = "producer", defaultValue = "1048576")
private Integer maxRequestSize = 1048576;
// receive.buffer.bytes
@UriParam(label = "producer", defaultValue = "65536")
private Integer receiveBufferBytes = 65536;
// request.timeout.ms
@UriParam(label = "producer", defaultValue = "30000")
private Integer requestTimeoutMs = 30000;
// delivery.timeout.ms
@UriParam(label = "producer", defaultValue = "120000")
private Integer deliveryTimeoutMs = 120000;
// send.buffer.bytes
@UriParam(label = "producer", defaultValue = "131072")
private Integer sendBufferBytes = 131072;
@UriParam(label = "producer", defaultValue = "true")
private boolean recordMetadata = true;
// max.in.flight.requests.per.connection
@UriParam(label = "producer", defaultValue = "5")
private Integer maxInFlightRequest = 5;
// metadata.max.age.ms
@UriParam(label = "producer", defaultValue = "300000")
private Integer metadataMaxAgeMs = 300000;
// metric.reporters
@UriParam(label = "producer")
private String metricReporters;
// metrics.num.samples
@UriParam(label = "producer", defaultValue = "2")
private Integer noOfMetricsSample = 2;
// metrics.sample.window.ms
@UriParam(label = "producer", defaultValue = "30000")
private Integer metricsSampleWindowMs = 30000;
// reconnect.backoff.ms
@UriParam(label = "producer", defaultValue = "50")
private Integer reconnectBackoffMs = 50;
// enable.idempotence
// reconnect.backoff.ms
@UriParam(label = "producer", defaultValue = "true")
private boolean enableIdempotence;
@UriParam(label = "producer", description = "To use a custom KafkaHeaderSerializer to serialize kafka headers values")
private KafkaHeaderSerializer headerSerializer = new DefaultKafkaHeaderSerializer();
// reconnect.backoff.max.ms
@UriParam(label = "common", defaultValue = "1000")
private Integer reconnectBackoffMaxMs = 1000;
// SSL
@UriParam(label = "common,security")
private SSLContextParameters sslContextParameters;
// SSL
// ssl.key.password
@UriParam(label = "common,security", secret = true)
private String sslKeyPassword;
// ssl.keystore.location
@UriParam(label = "common,security")
private String sslKeystoreLocation;
// ssl.keystore.password
@UriParam(label = "common,security", secret = true)
private String sslKeystorePassword;
// ssl.truststore.location
@UriParam(label = "common,security")
private String sslTruststoreLocation;
// ssl.truststore.password
@UriParam(label = "common,security", secret = true)
private String sslTruststorePassword;
// SSL
// ssl.enabled.protocols
@UriParam(label = "common,security")
private String sslEnabledProtocols = SslConfigs.DEFAULT_SSL_ENABLED_PROTOCOLS;
// ssl.keystore.type
@UriParam(label = "common,security", defaultValue = SslConfigs.DEFAULT_SSL_KEYSTORE_TYPE)
private String sslKeystoreType = SslConfigs.DEFAULT_SSL_KEYSTORE_TYPE;
// ssl.protocol
@UriParam(label = "common,security")
private String sslProtocol = SslConfigs.DEFAULT_SSL_PROTOCOL;
// ssl.provider
@UriParam(label = "common,security")
private String sslProvider;
// ssl.truststore.type
@UriParam(label = "common,security", defaultValue = SslConfigs.DEFAULT_SSL_TRUSTSTORE_TYPE)
private String sslTruststoreType = SslConfigs.DEFAULT_SSL_TRUSTSTORE_TYPE;
// SSL
// ssl.cipher.suites
@UriParam(label = "common,security")
private String sslCipherSuites;
// ssl.endpoint.identification.algorithm
@UriParam(label = "common,security", defaultValue = "https")
private String sslEndpointAlgorithm = SslConfigs.DEFAULT_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM;
// ssl.keymanager.algorithm
@UriParam(label = "common,security", defaultValue = "SunX509")
private String sslKeymanagerAlgorithm = "SunX509";
// ssl.trustmanager.algorithm
@UriParam(label = "common,security", defaultValue = "PKIX")
private String sslTrustmanagerAlgorithm = "PKIX";
// SASL & sucurity Protocol
// sasl.kerberos.service.name
@UriParam(label = "common,security")
private String saslKerberosServiceName;
// security.protocol
@UriParam(label = "common,security", defaultValue = CommonClientConfigs.DEFAULT_SECURITY_PROTOCOL)
private String securityProtocol = CommonClientConfigs.DEFAULT_SECURITY_PROTOCOL;
// SASL
// sasl.mechanism
@UriParam(label = "common,security", defaultValue = SaslConfigs.DEFAULT_SASL_MECHANISM)
private String saslMechanism = SaslConfigs.DEFAULT_SASL_MECHANISM;
// sasl.kerberos.kinit.cmd
@UriParam(label = "common,security", defaultValue = SaslConfigs.DEFAULT_KERBEROS_KINIT_CMD)
private String kerberosInitCmd = SaslConfigs.DEFAULT_KERBEROS_KINIT_CMD;
// sasl.kerberos.min.time.before.relogin
@UriParam(label = "common,security", defaultValue = "60000")
private Integer kerberosBeforeReloginMinTime = 60000;
// sasl.kerberos.ticket.renew.jitter
@UriParam(label = "common,security", defaultValue = "0.05")
private Double kerberosRenewJitter = SaslConfigs.DEFAULT_KERBEROS_TICKET_RENEW_JITTER;
// sasl.kerberos.ticket.renew.window.factor
@UriParam(label = "common,security", defaultValue = "0.8")
private Double kerberosRenewWindowFactor = SaslConfigs.DEFAULT_KERBEROS_TICKET_RENEW_WINDOW_FACTOR;
@UriParam(label = "common,security", defaultValue = "DEFAULT")
// sasl.kerberos.principal.to.local.rules
private String kerberosPrincipalToLocalRules;
@UriParam(label = "common,security", secret = true)
// sasl.jaas.config
private String saslJaasConfig;
// Schema registry only options
@UriParam(label = "schema")
private String schemaRegistryURL;
@UriParam(label = "schema,consumer")
private boolean specificAvroReader;
// Additional properties
@UriParam(label = "common", prefix = "additionalProperties.", multiValue = true)
private Map additionalProperties = new HashMap<>();
@UriParam(label = "common", defaultValue = "30000")
private int shutdownTimeout = 30000;
@UriParam(defaultValue = "false", label = "advanced",
description = "Sets whether synchronous processing should be strictly used")
private boolean synchronous;
@UriParam(label = "common,security")
private String kerberosConfigLocation;
@UriParam(label = "consumer", defaultValue = "false")
private boolean batching;
public KafkaConfiguration() {
}
/**
* Returns a copy of this configuration
*/
public KafkaConfiguration copy() {
try {
KafkaConfiguration copy = (KafkaConfiguration) clone();
copy.additionalProperties = new HashMap<>(this.additionalProperties);
return copy;
} catch (CloneNotSupportedException e) {
throw new RuntimeCamelException(e);
}
}
public Properties createProducerProperties() {
Properties props = new Properties();
addPropertyIfNotEmpty(props, ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, getKeySerializer());
addPropertyIfNotEmpty(props, ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, getValueSerializer());
addPropertyIfNotEmpty(props, ProducerConfig.ACKS_CONFIG, getRequestRequiredAcks());
addPropertyIfNotEmpty(props, ProducerConfig.BUFFER_MEMORY_CONFIG, getBufferMemorySize());
addPropertyIfNotEmpty(props, ProducerConfig.COMPRESSION_TYPE_CONFIG, getCompressionCodec());
addPropertyIfNotEmpty(props, ProducerConfig.RETRIES_CONFIG, getRetries());
addPropertyIfNotEmpty(props, ProducerConfig.INTERCEPTOR_CLASSES_CONFIG, getInterceptorClasses());
addPropertyIfNotEmpty(props, ProducerConfig.BATCH_SIZE_CONFIG, getProducerBatchSize());
addPropertyIfNotEmpty(props, ProducerConfig.CLIENT_ID_CONFIG, getClientId());
addPropertyIfNotEmpty(props, ProducerConfig.CONNECTIONS_MAX_IDLE_MS_CONFIG, getConnectionMaxIdleMs());
addPropertyIfNotEmpty(props, ProducerConfig.LINGER_MS_CONFIG, getLingerMs());
addPropertyIfNotEmpty(props, ProducerConfig.MAX_BLOCK_MS_CONFIG, getMaxBlockMs());
addPropertyIfNotEmpty(props, ProducerConfig.MAX_REQUEST_SIZE_CONFIG, getMaxRequestSize());
addPropertyIfNotEmpty(props, ProducerConfig.PARTITIONER_CLASS_CONFIG, getPartitioner());
addPropertyIfNotEmpty(props, ProducerConfig.PARTITIONER_IGNORE_KEYS_CONFIG, isPartitionerIgnoreKeys());
addPropertyIfNotEmpty(props, ProducerConfig.RECEIVE_BUFFER_CONFIG, getReceiveBufferBytes());
addPropertyIfNotEmpty(props, ProducerConfig.REQUEST_TIMEOUT_MS_CONFIG, getRequestTimeoutMs());
addPropertyIfNotEmpty(props, ProducerConfig.DELIVERY_TIMEOUT_MS_CONFIG, getDeliveryTimeoutMs());
addPropertyIfNotEmpty(props, ProducerConfig.SEND_BUFFER_CONFIG, getSendBufferBytes());
addPropertyIfNotEmpty(props, ProducerConfig.MAX_IN_FLIGHT_REQUESTS_PER_CONNECTION, getMaxInFlightRequest());
addPropertyIfNotEmpty(props, ProducerConfig.METADATA_MAX_AGE_CONFIG, getMetadataMaxAgeMs());
addPropertyIfNotEmpty(props, ProducerConfig.METRIC_REPORTER_CLASSES_CONFIG, getMetricReporters());
addPropertyIfNotEmpty(props, ProducerConfig.METRICS_NUM_SAMPLES_CONFIG, getNoOfMetricsSample());
addPropertyIfNotEmpty(props, ProducerConfig.METRICS_SAMPLE_WINDOW_MS_CONFIG, getMetricsSampleWindowMs());
addPropertyIfNotEmpty(props, ProducerConfig.RECONNECT_BACKOFF_MS_CONFIG, getReconnectBackoffMs());
addPropertyIfNotEmpty(props, ProducerConfig.RETRY_BACKOFF_MS_CONFIG, getRetryBackoffMs());
addPropertyIfNotEmpty(props, ProducerConfig.RETRY_BACKOFF_MAX_MS_CONFIG, getRetryBackoffMaxMs());
addPropertyIfNotEmpty(props, ProducerConfig.ENABLE_IDEMPOTENCE_CONFIG, isEnableIdempotence());
addPropertyIfNotEmpty(props, ProducerConfig.RECONNECT_BACKOFF_MAX_MS_CONFIG, getReconnectBackoffMaxMs());
addPropertyIfNotEmpty(props, "schema.registry.url", getSchemaRegistryURL());
// SSL
if (sslContextParameters != null) {
applySslConfigurationFromContext(props, sslContextParameters);
} else {
applyProducerSslConfiguration(props);
}
addPropertyIfNotEmpty(props, CommonClientConfigs.SECURITY_PROTOCOL_CONFIG, securityProtocol);
// SASL
if (isSasl(securityProtocol)) {
applySaslConfiguration(props);
}
// additional properties
applyAdditionalProperties(props, getAdditionalProperties());
return props;
}
private void applySaslConfiguration(Properties props) {
addPropertyIfNotEmpty(props, SaslConfigs.SASL_KERBEROS_SERVICE_NAME, getSaslKerberosServiceName());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_KERBEROS_KINIT_CMD, getKerberosInitCmd());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_KERBEROS_MIN_TIME_BEFORE_RELOGIN, getKerberosBeforeReloginMinTime());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_KERBEROS_TICKET_RENEW_JITTER, getKerberosRenewJitter());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_KERBEROS_TICKET_RENEW_WINDOW_FACTOR, getKerberosRenewWindowFactor());
addPropertyIfNotEmpty(props, BrokerSecurityConfigs.SASL_KERBEROS_PRINCIPAL_TO_LOCAL_RULES_CONFIG,
getKerberosPrincipalToLocalRules());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_MECHANISM, getSaslMechanism());
addPropertyIfNotEmpty(props, SaslConfigs.SASL_JAAS_CONFIG, getSaslJaasConfig());
}
private void applyProducerSslConfiguration(Properties props) {
if (securityProtocol.equals(SecurityProtocol.SSL.name()) || securityProtocol.equals(SecurityProtocol.SASL_SSL.name())) {
addPropertyIfNotEmpty(props, CommonClientConfigs.SECURITY_PROTOCOL_CONFIG, getSecurityProtocol());
addPropertyIfNotNull(props, SslConfigs.SSL_KEY_PASSWORD_CONFIG, getSslKeyPassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_LOCATION_CONFIG, getSslKeystoreLocation());
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_PASSWORD_CONFIG, getSslKeystorePassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_LOCATION_CONFIG, getSslTruststoreLocation());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_PASSWORD_CONFIG, getSslTruststorePassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_ENABLED_PROTOCOLS_CONFIG, getSslEnabledProtocols());
addUpperCasePropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_TYPE_CONFIG, getSslKeystoreType());
addPropertyIfNotEmpty(props, SslConfigs.SSL_PROTOCOL_CONFIG, getSslProtocol());
addPropertyIfNotEmpty(props, SslConfigs.SSL_PROVIDER_CONFIG, getSslProvider());
addUpperCasePropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG, getSslTruststoreType());
addPropertyIfNotEmpty(props, SslConfigs.SSL_CIPHER_SUITES_CONFIG, getSslCipherSuites());
String algo = getSslEndpointAlgorithm();
if (algo != null && !algo.equals("none") && !algo.equals("false")) {
addPropertyIfNotNull(props, SslConfigs.SSL_ENDPOINT_IDENTIFICATION_ALGORITHM_CONFIG, algo);
}
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYMANAGER_ALGORITHM_CONFIG, getSslKeymanagerAlgorithm());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTMANAGER_ALGORITHM_CONFIG, getSslTrustmanagerAlgorithm());
}
}
public Properties createConsumerProperties() {
Properties props = new Properties();
addPropertyIfNotEmpty(props, ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, getKeyDeserializer());
addPropertyIfNotEmpty(props, ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, getValueDeserializer());
addPropertyIfNotEmpty(props, ConsumerConfig.FETCH_MIN_BYTES_CONFIG, getFetchMinBytes());
addPropertyIfNotEmpty(props, ConsumerConfig.FETCH_MAX_BYTES_CONFIG, getFetchMaxBytes());
addPropertyIfNotEmpty(props, ConsumerConfig.HEARTBEAT_INTERVAL_MS_CONFIG, getHeartbeatIntervalMs());
addPropertyIfNotEmpty(props, ConsumerConfig.MAX_PARTITION_FETCH_BYTES_CONFIG, getMaxPartitionFetchBytes());
addPropertyIfNotEmpty(props, ConsumerConfig.SESSION_TIMEOUT_MS_CONFIG, getSessionTimeoutMs());
addPropertyIfNotEmpty(props, ConsumerConfig.MAX_POLL_INTERVAL_MS_CONFIG, getMaxPollIntervalMs());
addPropertyIfNotEmpty(props, ConsumerConfig.MAX_POLL_RECORDS_CONFIG, getMaxPollRecords());
addPropertyIfNotEmpty(props, ConsumerConfig.INTERCEPTOR_CLASSES_CONFIG, getInterceptorClasses());
addPropertyIfNotEmpty(props, ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, getAutoOffsetReset());
addPropertyIfNotEmpty(props, ConsumerConfig.CONNECTIONS_MAX_IDLE_MS_CONFIG, getConnectionMaxIdleMs());
addPropertyIfNotEmpty(props, ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, getAutoCommitEnable());
addPropertyIfNotEmpty(props, ConsumerConfig.PARTITION_ASSIGNMENT_STRATEGY_CONFIG, getPartitionAssignor());
addPropertyIfNotEmpty(props, ConsumerConfig.RECEIVE_BUFFER_CONFIG, getReceiveBufferBytes());
addPropertyIfNotEmpty(props, ConsumerConfig.REQUEST_TIMEOUT_MS_CONFIG, getConsumerRequestTimeoutMs());
addPropertyIfNotEmpty(props, ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, getAutoCommitIntervalMs());
addPropertyIfNotEmpty(props, ConsumerConfig.CHECK_CRCS_CONFIG, getCheckCrcs());
addPropertyIfNotEmpty(props, ConsumerConfig.CLIENT_ID_CONFIG, getClientId());
addPropertyIfNotEmpty(props, ConsumerConfig.FETCH_MAX_WAIT_MS_CONFIG, getFetchWaitMaxMs());
addPropertyIfNotEmpty(props, ConsumerConfig.METADATA_MAX_AGE_CONFIG, getMetadataMaxAgeMs());
addPropertyIfNotEmpty(props, ConsumerConfig.METRIC_REPORTER_CLASSES_CONFIG, getMetricReporters());
addPropertyIfNotEmpty(props, ConsumerConfig.METRICS_NUM_SAMPLES_CONFIG, getNoOfMetricsSample());
addPropertyIfNotEmpty(props, ConsumerConfig.METRICS_SAMPLE_WINDOW_MS_CONFIG, getMetricsSampleWindowMs());
addPropertyIfNotEmpty(props, ConsumerConfig.RECONNECT_BACKOFF_MS_CONFIG, getReconnectBackoffMs());
addPropertyIfNotEmpty(props, ConsumerConfig.RETRY_BACKOFF_MS_CONFIG, getRetryBackoffMs());
addPropertyIfNotEmpty(props, ConsumerConfig.RETRY_BACKOFF_MAX_MS_CONFIG, getRetryBackoffMaxMs());
addPropertyIfNotEmpty(props, ConsumerConfig.RECONNECT_BACKOFF_MAX_MS_CONFIG, getReconnectBackoffMaxMs());
addPropertyIfNotEmpty(props, ConsumerConfig.ISOLATION_LEVEL_CONFIG, getIsolationLevel());
addPropertyIfNotEmpty(props, "schema.registry.url", getSchemaRegistryURL());
addPropertyIfNotFalse(props, "specific.avro.reader", isSpecificAvroReader());
// SSL
if (sslContextParameters != null) {
applySslConfigurationFromContext(props, sslContextParameters);
} else {
applySslConsumerConfigurationFromOptions(props);
}
// Security protocol
addPropertyIfNotEmpty(props, CommonClientConfigs.SECURITY_PROTOCOL_CONFIG, securityProtocol);
// SASL
if (isSasl(securityProtocol)) {
applySaslConfiguration(props);
}
// additional properties
applyAdditionalProperties(props, getAdditionalProperties());
return props;
}
private boolean isSasl(String securityProtocol) {
return securityProtocol.equals(SecurityProtocol.SASL_PLAINTEXT.name())
|| securityProtocol.equals(SecurityProtocol.SASL_SSL.name());
}
private void applySslConsumerConfigurationFromOptions(Properties props) {
if (securityProtocol.equals(SecurityProtocol.SSL.name()) || securityProtocol.equals(SecurityProtocol.SASL_SSL.name())) {
addPropertyIfNotNull(props, SslConfigs.SSL_KEY_PASSWORD_CONFIG, getSslKeyPassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_LOCATION_CONFIG, getSslKeystoreLocation());
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_PASSWORD_CONFIG, getSslKeystorePassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_LOCATION_CONFIG, getSslTruststoreLocation());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_PASSWORD_CONFIG, getSslTruststorePassword());
addPropertyIfNotEmpty(props, SslConfigs.SSL_CIPHER_SUITES_CONFIG, getSslCipherSuites());
String algo = getSslEndpointAlgorithm();
if (algo != null && !algo.equals("none") && !algo.equals("false")) {
addPropertyIfNotNull(props, SslConfigs.SSL_ENDPOINT_IDENTIFICATION_ALGORITHM_CONFIG, algo);
}
addPropertyIfNotEmpty(props, SslConfigs.SSL_KEYMANAGER_ALGORITHM_CONFIG, getSslKeymanagerAlgorithm());
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTMANAGER_ALGORITHM_CONFIG, getSslTrustmanagerAlgorithm());
addPropertyIfNotEmpty(props, SslConfigs.SSL_ENABLED_PROTOCOLS_CONFIG, getSslEnabledProtocols());
addUpperCasePropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_TYPE_CONFIG, getSslKeystoreType());
addPropertyIfNotEmpty(props, SslConfigs.SSL_PROTOCOL_CONFIG, getSslProtocol());
addPropertyIfNotEmpty(props, SslConfigs.SSL_PROVIDER_CONFIG, getSslProvider());
addUpperCasePropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG, getSslTruststoreType());
addPropertyIfNotEmpty(props, ProducerConfig.SEND_BUFFER_CONFIG, getSendBufferBytes());
}
}
/**
* Uses the standard camel {@link SSLContextParameters} object to fill the Kafka SSL properties
*
* @param props Kafka properties
* @param sslContextParameters SSL configuration
*/
private void applySslConfigurationFromContext(Properties props, SSLContextParameters sslContextParameters) {
addPropertyIfNotNull(props, SslConfigs.SSL_PROTOCOL_CONFIG, sslContextParameters.getSecureSocketProtocol());
addPropertyIfNotNull(props, SslConfigs.SSL_PROVIDER_CONFIG, sslContextParameters.getProvider());
CipherSuitesParameters cipherSuites = sslContextParameters.getCipherSuites();
if (cipherSuites != null) {
addCommaSeparatedList(props, SslConfigs.SSL_CIPHER_SUITES_CONFIG, cipherSuites.getCipherSuite());
}
SecureSocketProtocolsParameters secureSocketProtocols = sslContextParameters.getSecureSocketProtocols();
if (secureSocketProtocols != null) {
addCommaSeparatedList(props, SslConfigs.SSL_ENABLED_PROTOCOLS_CONFIG,
secureSocketProtocols.getSecureSocketProtocol());
}
KeyManagersParameters keyManagers = sslContextParameters.getKeyManagers();
if (keyManagers != null) {
addPropertyIfNotNull(props, SslConfigs.SSL_KEYMANAGER_ALGORITHM_CONFIG, keyManagers.getAlgorithm());
addPropertyIfNotNull(props, SslConfigs.SSL_KEY_PASSWORD_CONFIG, keyManagers.getKeyPassword());
KeyStoreParameters keyStore = keyManagers.getKeyStore();
if (keyStore != null) {
// kakfa loads the resource itself and you cannot have a prefix
String location = keyStore.getResource();
if (ResourceHelper.hasScheme(location)) {
location = StringHelper.after(location, ":");
}
addUpperCasePropertyIfNotEmpty(props, SslConfigs.SSL_KEYSTORE_TYPE_CONFIG, keyStore.getType());
addPropertyIfNotNull(props, SslConfigs.SSL_KEYSTORE_LOCATION_CONFIG, location);
addPropertyIfNotNull(props, SslConfigs.SSL_KEYSTORE_PASSWORD_CONFIG, keyStore.getPassword());
}
}
TrustManagersParameters trustManagers = sslContextParameters.getTrustManagers();
if (trustManagers != null) {
addPropertyIfNotNull(props, SslConfigs.SSL_TRUSTMANAGER_ALGORITHM_CONFIG, trustManagers.getAlgorithm());
KeyStoreParameters keyStore = trustManagers.getKeyStore();
if (keyStore != null) {
// kakfa loads the resource itself and you cannot have a prefix
String location = keyStore.getResource();
if (ResourceHelper.hasScheme(location)) {
location = StringHelper.after(location, ":");
}
addPropertyIfNotNull(props, SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG, keyStore.getType());
addPropertyIfNotNull(props, SslConfigs.SSL_TRUSTSTORE_LOCATION_CONFIG, location);
addPropertyIfNotEmpty(props, SslConfigs.SSL_TRUSTSTORE_PASSWORD_CONFIG, keyStore.getPassword());
}
}
}
private void applyAdditionalProperties(final Properties props, final Map additionalProperties) {
if (!ObjectHelper.isEmpty(getAdditionalProperties())) {
additionalProperties.forEach((property, value) -> {
if (value != null) {
// value should be as-is
props.put(property, value);
}
});
}
}
private static void addPropertyIfNotFalse(Properties props, String key, boolean value) {
if (value) {
// value should be as-is
props.put(key, value);
}
}
private static void addPropertyIfNotEmpty(Properties props, String key, T value) {
if (ObjectHelper.isNotEmpty(value)) {
// value should be as-is
props.put(key, value);
}
}
private static void addUpperCasePropertyIfNotEmpty(Properties props, String key, T value) {
if (ObjectHelper.isNotEmpty(value)) {
props.put(key, String.valueOf(value).toUpperCase(Locale.ROOT));
}
}
private static void addPropertyIfNotNull(Properties props, String key, T value) {
if (value != null) {
// value should be as-is
props.put(key, value);
}
}
private static void addCommaSeparatedList(Properties props, String key, List values) {
if (values != null && !values.isEmpty()) {
props.put(key, values.stream().collect(Collectors.joining(",")));
}
}
public boolean isPreValidateHostAndPort() {
return preValidateHostAndPort;
}
/**
* Whether to eager validate that broker host:port is valid and can be DNS resolved to known host during starting
* this consumer. If the validation fails, then an exception is thrown, which makes Camel fail fast.
*
* Disabling this will postpone the validation after the consumer is started, and Camel will keep re-connecting in
* case of validation or DNS resolution error.
*/
public void setPreValidateHostAndPort(boolean preValidateHostAndPort) {
this.preValidateHostAndPort = preValidateHostAndPort;
}
public boolean isTopicIsPattern() {
return topicIsPattern;
}
/**
* Whether the topic is a pattern (regular expression). This can be used to subscribe to dynamic number of topics
* matching the pattern.
*/
public void setTopicIsPattern(boolean topicIsPattern) {
this.topicIsPattern = topicIsPattern;
}
public String getGroupId() {
return groupId;
}
/**
* A string that uniquely identifies the group of consumer processes to which this consumer belongs. By setting the
* same group id, multiple processes can indicate that they are all part of the same consumer group. This option is
* required for consumers.
*/
public void setGroupId(String groupId) {
this.groupId = groupId;
}
public String getGroupInstanceId() {
return groupInstanceId;
}
/**
* A unique identifier of the consumer instance provided by the end user. Only non-empty strings are permitted. If
* set, the consumer is treated as a static member, which means that only one instance with this ID is allowed in
* the consumer group at any time. This can be used in combination with a larger session timeout to avoid group
* rebalances caused by transient unavailability (e.g., process restarts). If not set, the consumer will join the
* group as a dynamic member, which is the traditional behavior.
*/
public void setGroupInstanceId(String groupInstanceId) {
this.groupInstanceId = groupInstanceId;
}
public String getPartitioner() {
return partitioner;
}
/**
* The partitioner class for partitioning messages amongst sub-topics. The default partitioner is based on the hash
* of the key.
*/
public void setPartitioner(String partitioner) {
this.partitioner = partitioner;
}
/**
* Whether the message keys should be ignored when computing the partition. This setting has effect only when
* {@link #partitioner} is not set
*/
public boolean isPartitionerIgnoreKeys() {
return partitionerIgnoreKeys;
}
public void setPartitionerIgnoreKeys(boolean partitionerIgnoreKeys) {
this.partitionerIgnoreKeys = partitionerIgnoreKeys;
}
public String getTopic() {
return topic;
}
/**
* Name of the topic to use. On the consumer you can use comma to separate multiple topics. A producer can only send
* a message to a single topic.
*/
public void setTopic(String topic) {
this.topic = topic;
}
public int getConsumersCount() {
return consumersCount;
}
/**
* The number of consumers that connect to kafka server. Each consumer is run on a separate thread that retrieves
* and process the incoming data.
*/
public void setConsumersCount(int consumersCount) {
this.consumersCount = consumersCount;
}
public String getClientId() {
return clientId;
}
/**
* The client id is a user-specified string sent in each request to help trace calls. It should logically identify
* the application making the request.
*/
public void setClientId(String clientId) {
this.clientId = clientId;
}
public boolean isAutoCommitEnable() {
return offsetRepository == null && autoCommitEnable;
}
public boolean getAutoCommitEnable() {
if (!batching) {
return autoCommitEnable;
}
return false;
}
/**
* If true, periodically commit to ZooKeeper the offset of messages already fetched by the consumer. This committed
* offset will be used when the process fails as the position from which the new consumer will begin.
*/
public void setAutoCommitEnable(boolean autoCommitEnable) {
this.autoCommitEnable = autoCommitEnable;
}
public boolean isAllowManualCommit() {
return allowManualCommit;
}
/**
* Whether to allow doing manual commits via {@link KafkaManualCommit}.
*
* If this option is enabled then an instance of {@link KafkaManualCommit} is stored on the {@link Exchange} message
* header, which allows end users to access this API and perform manual offset commits via the Kafka consumer.
*/
public void setAllowManualCommit(boolean allowManualCommit) {
this.allowManualCommit = allowManualCommit;
}
public int getShutdownTimeout() {
return shutdownTimeout;
}
/**
* Timeout in milliseconds to wait gracefully for the consumer or producer to shut down and terminate its worker
* threads.
*/
public void setShutdownTimeout(int shutdownTimeout) {
this.shutdownTimeout = shutdownTimeout;
}
public StateRepository getOffsetRepository() {
return offsetRepository;
}
/**
* The offset repository to use to locally store the offset of each partition of the topic. Defining one will
* disable the autocommit.
*/
public void setOffsetRepository(StateRepository offsetRepository) {
this.offsetRepository = offsetRepository;
}
public Integer getAutoCommitIntervalMs() {
return autoCommitIntervalMs;
}
/**
* The frequency in ms that the consumer offsets are committed to zookeeper.
*/
public void setAutoCommitIntervalMs(Integer autoCommitIntervalMs) {
this.autoCommitIntervalMs = autoCommitIntervalMs;
}
public Integer getFetchMinBytes() {
return fetchMinBytes;
}
/**
* The minimum amount of data the server should return for a fetch request. If insufficient data is available, the
* request will wait for that much data to accumulate before answering the request.
*/
public void setFetchMinBytes(Integer fetchMinBytes) {
this.fetchMinBytes = fetchMinBytes;
}
/**
* The maximum amount of data the server should return for a fetch request. This is not an absolute maximum, if the
* first message in the first non-empty partition of the fetch is larger than this value, the message will still be
* returned to ensure that the consumer can make progress. The maximum message size accepted by the broker is
* defined via message.max.bytes (broker config) or max.message.bytes (topic config). Note that the consumer
* performs multiple fetches in parallel.
*/
public Integer getFetchMaxBytes() {
return fetchMaxBytes;
}
public void setFetchMaxBytes(Integer fetchMaxBytes) {
this.fetchMaxBytes = fetchMaxBytes;
}
public Integer getFetchWaitMaxMs() {
return fetchWaitMaxMs;
}
/**
* The maximum amount of time the server will block before answering the fetch request if there isn't enough data to
* immediately satisfy fetch.min.bytes
*/
public void setFetchWaitMaxMs(Integer fetchWaitMaxMs) {
this.fetchWaitMaxMs = fetchWaitMaxMs;
}
public String getAutoOffsetReset() {
return autoOffsetReset;
}
/**
* What to do when there is no initial offset in ZooKeeper or if an offset is out of range: earliest : automatically
* reset the offset to the earliest offset latest: automatically reset the offset to the latest offset fail: throw
* exception to the consumer
*/
public void setAutoOffsetReset(String autoOffsetReset) {
this.autoOffsetReset = autoOffsetReset;
}
public boolean isBreakOnFirstError() {
return breakOnFirstError;
}
/**
* This options controls what happens when a consumer is processing an exchange and it fails. If the option is
* false then the consumer continues to the next message and processes it. If the option is true
* then the consumer breaks out.
*
* Using the default NoopCommitManager will cause the consumer to not commit the offset so that the message is
* re-attempted. The consumer should use the KafkaManualCommit to determine the best way to handle the message.
*
* Using either the SyncCommitManager or the AsyncCommitManager, the consumer will seek back to the offset of the
* message that caused a failure, and then re-attempt to process this message. However, this can lead to endless
* processing of the same message if it's bound to fail every time, e.g., a poison message. Therefore, it's
* recommended to deal with that, for example, by using Camel's error handler.
*/
public void setBreakOnFirstError(boolean breakOnFirstError) {
this.breakOnFirstError = breakOnFirstError;
}
public String getBrokers() {
return brokers;
}
/**
* URL of the Kafka brokers to use. The format is host1:port1,host2:port2, and the list can be a subset of brokers
* or a VIP pointing to a subset of brokers.
*
* This option is known as bootstrap.servers in the Kafka documentation.
*/
public void setBrokers(String brokers) {
this.brokers = brokers;
}
public String getSchemaRegistryURL() {
return schemaRegistryURL;
}
/**
* URL of the schema registry servers to use. The format is host1:port1,host2:port2. This is known as
* schema.registry.url in multiple Schema registries documentation. This option is only available externally (not
* standard Apache Kafka)
*/
public void setSchemaRegistryURL(String schemaRegistryURL) {
this.schemaRegistryURL = schemaRegistryURL;
}
public boolean isSpecificAvroReader() {
return specificAvroReader;
}
/**
* This enables the use of a specific Avro reader for use with the in multiple Schema registries documentation with
* Avro Deserializers implementation. This option is only available externally (not standard Apache Kafka)
*/
public void setSpecificAvroReader(boolean specificAvroReader) {
this.specificAvroReader = specificAvroReader;
}
public String getCompressionCodec() {
return compressionCodec;
}
/**
* This parameter allows you to specify the compression codec for all data generated by this producer. Valid values
* are "none", "gzip", "snappy", "lz4" and "zstd".
*/
public void setCompressionCodec(String compressionCodec) {
this.compressionCodec = compressionCodec;
}
public Integer getRetryBackoffMs() {
return retryBackoffMs;
}
/**
* The amount of time to wait before attempting to retry a failed request to a given topic partition. This avoids
* repeatedly sending requests in a tight loop under some failure scenarios. This value is the initial backoff value
* and will increase exponentially for each failed request, up to the retry.backoff.max.ms value.
*/
public void setRetryBackoffMs(Integer retryBackoffMs) {
this.retryBackoffMs = retryBackoffMs;
}
public Integer getRetryBackoffMaxMs() {
return retryBackoffMaxMs;
}
/**
* The maximum amount of time in milliseconds to wait when retrying a request to the broker that has repeatedly
* failed. If provided, the backoff per client will increase exponentially for each failed request, up to this
* maximum. To prevent all clients from being synchronized upon retry, a randomized jitter with a factor of 0.2 will
* be applied to the backoff, resulting in the backoff falling within a range between 20% below and 20% above the
* computed value. If retry.backoff.ms is set to be higher than retry.backoff.max.ms, then retry.backoff.max.ms will
* be used as a constant backoff from the beginning without any exponential increase
*/
public void setRetryBackoffMaxMs(Integer retryBackoffMaxMs) {
this.retryBackoffMaxMs = retryBackoffMaxMs;
}
public Integer getSendBufferBytes() {
return sendBufferBytes;
}
/**
* Socket write buffer size
*/
public void setSendBufferBytes(Integer sendBufferBytes) {
this.sendBufferBytes = sendBufferBytes;
}
public Integer getRequestTimeoutMs() {
return requestTimeoutMs;
}
/**
* The amount of time the broker will wait trying to meet the request.required.acks requirement before sending back
* an error to the client.
*/
public void setRequestTimeoutMs(Integer requestTimeoutMs) {
this.requestTimeoutMs = requestTimeoutMs;
}
public Integer getDeliveryTimeoutMs() {
return deliveryTimeoutMs;
}
/**
* An upper bound on the time to report success or failure after a call to send() returns. This limits the total
* time that a record will be delayed prior to sending, the time to await acknowledgement from the broker (if
* expected), and the time allowed for retriable send failures.
*/
public void setDeliveryTimeoutMs(Integer deliveryTimeoutMs) {
this.deliveryTimeoutMs = deliveryTimeoutMs;
}
public Integer getQueueBufferingMaxMessages() {
return queueBufferingMaxMessages;
}
/**
* The maximum number of unsent messages that can be queued up the producer when using async mode before either the
* producer must be blocked or data must be dropped.
*/
public void setQueueBufferingMaxMessages(Integer queueBufferingMaxMessages) {
this.queueBufferingMaxMessages = queueBufferingMaxMessages;
}
public String getValueSerializer() {
return valueSerializer;
}
/**
* The serializer class for messages.
*/
public void setValueSerializer(String valueSerializer) {
this.valueSerializer = valueSerializer;
}
public String getKeySerializer() {
return keySerializer;
}
/**
* The serializer class for keys (defaults to the same as for messages if nothing is given).
*/
public void setKeySerializer(String keySerializer) {
this.keySerializer = keySerializer;
}
public String getKerberosInitCmd() {
return kerberosInitCmd;
}
/**
* Kerberos kinit command path. Default is /usr/bin/kinit
*/
public void setKerberosInitCmd(String kerberosInitCmd) {
this.kerberosInitCmd = kerberosInitCmd;
}
public Integer getKerberosBeforeReloginMinTime() {
return kerberosBeforeReloginMinTime;
}
/**
* Login thread sleep time between refresh attempts.
*/
public void setKerberosBeforeReloginMinTime(Integer kerberosBeforeReloginMinTime) {
this.kerberosBeforeReloginMinTime = kerberosBeforeReloginMinTime;
}
public Double getKerberosRenewJitter() {
return kerberosRenewJitter;
}
/**
* Percentage of random jitter added to the renewal time.
*/
public void setKerberosRenewJitter(Double kerberosRenewJitter) {
this.kerberosRenewJitter = kerberosRenewJitter;
}
public Double getKerberosRenewWindowFactor() {
return kerberosRenewWindowFactor;
}
/**
* Login thread will sleep until the specified window factor of time from last refresh to ticket's expiry has been
* reached, at which time it will try to renew the ticket.
*/
public void setKerberosRenewWindowFactor(Double kerberosRenewWindowFactor) {
this.kerberosRenewWindowFactor = kerberosRenewWindowFactor;
}
public String getKerberosPrincipalToLocalRules() {
return kerberosPrincipalToLocalRules;
}
/**
* A list of rules for mapping from principal names to short names (typically operating system usernames). The rules
* are evaluated in order, and the first rule that matches a principal name is used to map it to a short name. Any
* later rules in the list are ignored. By default, principal names of the form {username}/{hostname}@{REALM} are
* mapped to {username}. For more details on the format, please see the Security Authorization and ACLs
* documentation (at the Apache Kafka project website).
*
* Multiple values can be separated by comma
*/
public void setKerberosPrincipalToLocalRules(String kerberosPrincipalToLocalRules) {
this.kerberosPrincipalToLocalRules = kerberosPrincipalToLocalRules;
}
public String getSslCipherSuites() {
return sslCipherSuites;
}
/**
* A list of cipher suites. This is a named combination of authentication, encryption, MAC and key exchange
* algorithm used to negotiate the security settings for a network connection using TLS or SSL network protocol. By
* default, all the available cipher suites are supported.
*/
public void setSslCipherSuites(String sslCipherSuites) {
this.sslCipherSuites = sslCipherSuites;
}
public String getSslEndpointAlgorithm() {
return sslEndpointAlgorithm;
}
/**
* The endpoint identification algorithm to validate server hostname using server certificate. Use none or false to
* disable server hostname verification.
*/
public void setSslEndpointAlgorithm(String sslEndpointAlgorithm) {
this.sslEndpointAlgorithm = sslEndpointAlgorithm;
}
public String getSslKeymanagerAlgorithm() {
return sslKeymanagerAlgorithm;
}
/**
* The algorithm used by key manager factory for SSL connections. Default value is the key manager factory algorithm
* configured for the Java Virtual Machine.
*/
public void setSslKeymanagerAlgorithm(String sslKeymanagerAlgorithm) {
this.sslKeymanagerAlgorithm = sslKeymanagerAlgorithm;
}
public String getSslTrustmanagerAlgorithm() {
return sslTrustmanagerAlgorithm;
}
/**
* The algorithm used by trust manager factory for SSL connections. Default value is the trust manager factory
* algorithm configured for the Java Virtual Machine.
*/
public void setSslTrustmanagerAlgorithm(String sslTrustmanagerAlgorithm) {
this.sslTrustmanagerAlgorithm = sslTrustmanagerAlgorithm;
}
public String getSslEnabledProtocols() {
return sslEnabledProtocols;
}
/**
* The list of protocols enabled for SSL connections. The default is TLSv1.2,TLSv1.3 when running with Java 11 or
* newer, TLSv1.2 otherwise. With the default value for Java 11, clients and servers will prefer TLSv1.3 if both
* support it and fallback to TLSv1.2 otherwise (assuming both support at least TLSv1.2). This default should be
* fine for most cases. Also see the config documentation for SslProtocol.
*/
public void setSslEnabledProtocols(String sslEnabledProtocols) {
this.sslEnabledProtocols = sslEnabledProtocols;
}
public String getSslKeystoreType() {
return sslKeystoreType;
}
/**
* The file format of the key store file. This is optional for the client. The default value is JKS
*/
public void setSslKeystoreType(String sslKeystoreType) {
this.sslKeystoreType = sslKeystoreType;
}
public String getSslProtocol() {
return sslProtocol;
}
/**
* The SSL protocol used to generate the SSLContext. The default is TLSv1.3 when running with Java 11 or newer,
* TLSv1.2 otherwise. This value should be fine for most use cases. Allowed values in recent JVMs are TLSv1.2 and
* TLSv1.3. TLS, TLSv1.1, SSL, SSLv2 and SSLv3 may be supported in older JVMs, but their usage is discouraged due to
* known security vulnerabilities. With the default value for this config and sslEnabledProtocols, clients will
* downgrade to TLSv1.2 if the server does not support TLSv1.3. If this config is set to TLSv1.2, clients will not
* use TLSv1.3 even if it is one of the values in sslEnabledProtocols and the server only supports TLSv1.3.
*/
public void setSslProtocol(String sslProtocol) {
this.sslProtocol = sslProtocol;
}
public String getSslProvider() {
return sslProvider;
}
/**
* The name of the security provider used for SSL connections. Default value is the default security provider of the
* JVM.
*/
public void setSslProvider(String sslProvider) {
this.sslProvider = sslProvider;
}
public String getSslTruststoreType() {
return sslTruststoreType;
}
/**
* The file format of the trust store file. The default value is JKS.
*/
public void setSslTruststoreType(String sslTruststoreType) {
this.sslTruststoreType = sslTruststoreType;
}
public String getSaslKerberosServiceName() {
return saslKerberosServiceName;
}
/**
* The Kerberos principal name that Kafka runs as. This can be defined either in Kafka's JAAS config or in Kafka's
* config.
*/
public void setSaslKerberosServiceName(String saslKerberosServiceName) {
this.saslKerberosServiceName = saslKerberosServiceName;
}
public String getSaslMechanism() {
return saslMechanism;
}
/**
* The Simple Authentication and Security Layer (SASL) Mechanism used. For the valid values see http://www.iana.org/assignments/sasl-mechanisms/sasl-mechanisms.xhtml
*/
public void setSaslMechanism(String saslMechanism) {
this.saslMechanism = saslMechanism;
}
public String getSaslJaasConfig() {
return saslJaasConfig;
}
/**
* Expose the kafka sasl.jaas.config parameter Example: org.apache.kafka.common.security.plain.PlainLoginModule
* required username="USERNAME" password="PASSWORD";
*/
public void setSaslJaasConfig(String saslJaasConfig) {
this.saslJaasConfig = saslJaasConfig;
}
public String getSecurityProtocol() {
return securityProtocol;
}
/**
* Protocol used to communicate with brokers. SASL_PLAINTEXT, PLAINTEXT, SASL_SSL and SSL are supported
*/
public void setSecurityProtocol(String securityProtocol) {
this.securityProtocol = securityProtocol;
}
public SSLContextParameters getSslContextParameters() {
return sslContextParameters;
}
/**
* SSL configuration using a Camel {@link SSLContextParameters} object. If configured, it's applied before the other
* SSL endpoint parameters.
*
* NOTE: Kafka only supports loading keystore from file locations, so prefix the location with file: in the
* KeyStoreParameters.resource option.
*/
public void setSslContextParameters(SSLContextParameters sslContextParameters) {
this.sslContextParameters = sslContextParameters;
}
public String getSslKeyPassword() {
return sslKeyPassword;
}
/**
* The password of the private key in the key store file or the PEM key specified in sslKeystoreKey. This is
* required for clients only if two-way authentication is configured.
*/
public void setSslKeyPassword(String sslKeyPassword) {
this.sslKeyPassword = sslKeyPassword;
}
public String getSslKeystoreLocation() {
return sslKeystoreLocation;
}
/**
* The location of the key store file. This is optional for the client and can be used for two-way authentication
* for the client.
*/
public void setSslKeystoreLocation(String sslKeystoreLocation) {
this.sslKeystoreLocation = sslKeystoreLocation;
}
public String getSslKeystorePassword() {
return sslKeystorePassword;
}
/**
* The store password for the key store file. This is optional for the client and only needed if sslKeystoreLocation
* is configured. Key store password is not supported for PEM format.
*/
public void setSslKeystorePassword(String sslKeystorePassword) {
this.sslKeystorePassword = sslKeystorePassword;
}
public String getSslTruststoreLocation() {
return sslTruststoreLocation;
}
/**
* The location of the trust store file.
*/
public void setSslTruststoreLocation(String sslTruststoreLocation) {
this.sslTruststoreLocation = sslTruststoreLocation;
}
public String getSslTruststorePassword() {
return sslTruststorePassword;
}
/**
* The password for the trust store file. If a password is not set, trust store file configured will still be used,
* but integrity checking is disabled. Trust store password is not supported for PEM format.
*/
public void setSslTruststorePassword(String sslTruststorePassword) {
this.sslTruststorePassword = sslTruststorePassword;
}
public Integer getBufferMemorySize() {
return bufferMemorySize;
}
/**
* The total bytes of memory the producer can use to buffer records waiting to be sent to the server. If records are
* sent faster than they can be delivered to the server, the producer will either block or throw an exception based
* on the preference specified by block.on.buffer.full.This setting should correspond roughly to the total memory
* the producer will use, but is not a hard bound since not all memory the producer uses is used for buffering. Some
* additional memory will be used for compression (if compression is enabled) as well as for maintaining in-flight
* requests.
*/
public void setBufferMemorySize(Integer bufferMemorySize) {
this.bufferMemorySize = bufferMemorySize;
}
public String getKey() {
return key;
}
/**
* The record key (or null if no key is specified). If this option has been configured then it take precedence over
* header {@link KafkaConstants#KEY}
*/
public void setKey(String key) {
this.key = key;
}
public Integer getPartitionKey() {
return partitionKey;
}
/**
* The partition to which the record will be sent (or null if no partition was specified). If this option has been
* configured then it take precedence over header {@link KafkaConstants#PARTITION_KEY}
*/
public void setPartitionKey(Integer partitionKey) {
this.partitionKey = partitionKey;
}
public boolean isUseIterator() {
return useIterator;
}
/**
* Sets whether sending to kafka should send the message body as a single record, or use a java.util.Iterator to
* send multiple records to kafka (if the message body can be iterated).
*/
public void setUseIterator(boolean useIterator) {
this.useIterator = useIterator;
}
public String getRequestRequiredAcks() {
return requestRequiredAcks;
}
/**
* The number of acknowledgments the producer requires the leader to have received before considering a request
* complete. This controls the durability of records that are sent. The following settings are allowed:
*
* acks=0 If set to zero, then the producer will not wait for any acknowledgment from the server at all. The record
* will be immediately added to the socket buffer and considered sent. No guarantee can be made that the server has
* received the record in this case, and the retry configuration will not take effect (as the client won't generally
* know of any failures). The offset given back for each record will always be set to -1. acks=1 This will mean the
* leader will write the record to its local log but will respond without awaiting full acknowledgment from all
* followers. In this case should the leader fail immediately after acknowledging the record, but before the
* followers have replicated it, then the record will be lost. acks=all This means the leader will wait for the full
* set of in-sync replicas to acknowledge the record. This guarantees that the record will not be lost as long as at
* least one in-sync replica remains alive. This is the strongest available guarantee. This is equivalent to the
* acks=-1 setting. Note that enabling idempotence requires this config value to be 'all'. If conflicting
* configurations are set and idempotence is not explicitly enabled, idempotence is disabled.
*/
public void setRequestRequiredAcks(String requestRequiredAcks) {
this.requestRequiredAcks = requestRequiredAcks;
}
public Integer getRetries() {
return retries;
}
/**
* Setting a value greater than zero will cause the client to resend any record that has failed to be sent due to a
* potentially transient error. Note that this retry is no different from if the client re-sending the record upon
* receiving the error. Produce requests will be failed before the number of retries has been exhausted if the
* timeout configured by delivery.timeout.ms expires first before successful acknowledgement. Users should generally
* prefer to leave this config unset and instead use delivery.timeout.ms to control retry behavior.
*
* Enabling idempotence requires this config value to be greater than 0. If conflicting configurations are set and
* idempotence is not explicitly enabled, idempotence is disabled.
*
* Allowing retries while setting enable.idempotence to false and max.in.flight.requests.per.connection to 1 will
* potentially change the ordering of records, because if two batches are sent to a single partition, and the first
* fails and is retried but the second succeeds; then the records in the second batch may appear first.
*/
public void setRetries(Integer retries) {
this.retries = retries;
}
public Integer getProducerBatchSize() {
return producerBatchSize;
}
/**
* The producer will attempt to batch records together into fewer requests whenever multiple records are being sent
* to the same partition. This helps performance on both the client and the server. This configuration controls the
* default batch size in bytes. No attempt will be made to batch records larger than this size. Requests sent to
* brokers will contain multiple batches, one for each partition with data available to be sent. A small batch size
* will make batching less common and may reduce throughput (a batch size of zero will disable batching entirely). A
* very large batch size may use memory a bit more wastefully as we will always allocate a buffer of the specified
* batch size in anticipation of additional records.
*/
public void setProducerBatchSize(Integer producerBatchSize) {
this.producerBatchSize = producerBatchSize;
}
public boolean isBatchWithIndividualHeaders() {
return batchWithIndividualHeaders;
}
/**
* If this feature is enabled and a single element of a batch is an Exchange or Message, the producer will generate
* individual kafka header values for it by using the batch Message to determine the values. Normal behavior
* consists of always using the same header values (which are determined by the parent Exchange which contains the
* Iterable or Iterator).
*/
public void setBatchWithIndividualHeaders(boolean batchWithIndividualHeaders) {
this.batchWithIndividualHeaders = batchWithIndividualHeaders;
}
public Integer getConnectionMaxIdleMs() {
return connectionMaxIdleMs;
}
/**
* Close idle connections after the number of milliseconds specified by this config.
*/
public void setConnectionMaxIdleMs(Integer connectionMaxIdleMs) {
this.connectionMaxIdleMs = connectionMaxIdleMs;
}
public Integer getLingerMs() {
return lingerMs;
}
/**
* The producer groups together any records that arrive in between request transmissions into a single, batched,
* request. Normally, this occurs only under load when records arrive faster than they can be sent out. However, in
* some circumstances, the client may want to reduce the number of requests even under a moderate load. This setting
* achieves this by adding a small amount of artificial delay. That is, rather than immediately sending out a
* record, the producer will wait for up to the given delay to allow other records to be sent so that they can be
* batched together. This can be thought of as analogous to Nagle's algorithm in TCP. This setting gives the upper
* bound on the delay for batching: once we get batch.size worth of records for a partition, it will be sent
* immediately regardless of this setting, however, if we have fewer than this many bytes accumulated for this
* partition, we will 'linger' for the specified time waiting for more records to show up. This setting defaults to
* 0 (i.e., no delay). Setting linger.ms=5, for example, would have the effect of reducing the number of requests
* sent but would add up to 5ms of latency to records sent in the absence of load.
*/
public void setLingerMs(Integer lingerMs) {
this.lingerMs = lingerMs;
}
public Integer getMaxBlockMs() {
return maxBlockMs;
}
/**
* The configuration controls how long the KafkaProducer's send(), partitionsFor(), initTransactions(),
* sendOffsetsToTransaction(), commitTransaction() and abortTransaction() methods will block. For send() this
* timeout bounds the total time waiting for both metadata fetch and buffer allocation (blocking in the
* user-supplied serializers or partitioner is not counted against this timeout). For partitionsFor() this time out
* bounds the time spent waiting for metadata if it is unavailable. The transaction-related methods always block,
* but may time out if the transaction coordinator could not be discovered or did not respond within the timeout.
*/
public void setMaxBlockMs(Integer maxBlockMs) {
this.maxBlockMs = maxBlockMs;
}
public Integer getMaxRequestSize() {
return maxRequestSize;
}
/**
* The maximum size of a request. This is also effectively a cap on the maximum record size. Note that the server
* has its own cap on record size which may be different from this. This setting will limit the number of record
* batches the producer will send in a single request to avoid sending huge requests.
*/
public void setMaxRequestSize(Integer maxRequestSize) {
this.maxRequestSize = maxRequestSize;
}
public Integer getReceiveBufferBytes() {
return receiveBufferBytes;
}
/**
* The size of the TCP receive buffer (SO_RCVBUF) to use when reading data.
*/
public void setReceiveBufferBytes(Integer receiveBufferBytes) {
this.receiveBufferBytes = receiveBufferBytes;
}
public Integer getMaxInFlightRequest() {
return maxInFlightRequest;
}
/**
* The maximum number of unacknowledged requests the client will send on a single connection before blocking. Note
* that if this setting is set to be greater than 1 and there are failed sends, there is a risk of message
* re-ordering due to retries (i.e., if retries are enabled).
*/
public void setMaxInFlightRequest(Integer maxInFlightRequest) {
this.maxInFlightRequest = maxInFlightRequest;
}
public Integer getMetadataMaxAgeMs() {
return metadataMaxAgeMs;
}
/**
* The period of time in milliseconds after which we force a refresh of metadata even if we haven't seen any
* partition leadership changes to proactively discover any new brokers or partitions.
*/
public void setMetadataMaxAgeMs(Integer metadataMaxAgeMs) {
this.metadataMaxAgeMs = metadataMaxAgeMs;
}
public String getMetricReporters() {
return metricReporters;
}
/**
* A list of classes to use as metrics reporters. Implementing the MetricReporter interface allows plugging in
* classes that will be notified of new metric creation. The JmxReporter is always included to register JMX
* statistics.
*/
public void setMetricReporters(String metricReporters) {
this.metricReporters = metricReporters;
}
public Integer getNoOfMetricsSample() {
return noOfMetricsSample;
}
/**
* The number of samples maintained to compute metrics.
*/
public void setNoOfMetricsSample(Integer noOfMetricsSample) {
this.noOfMetricsSample = noOfMetricsSample;
}
public Integer getMetricsSampleWindowMs() {
return metricsSampleWindowMs;
}
/**
* The window of time a metrics sample is computed over.
*/
public void setMetricsSampleWindowMs(Integer metricsSampleWindowMs) {
this.metricsSampleWindowMs = metricsSampleWindowMs;
}
public Integer getReconnectBackoffMs() {
return reconnectBackoffMs;
}
/**
* The amount of time to wait before attempting to reconnect to a given host. This avoids repeatedly connecting to a
* host in a tight loop. This backoff applies to all requests sent by the consumer to the broker.
*/
public void setReconnectBackoffMs(Integer reconnectBackoffMs) {
this.reconnectBackoffMs = reconnectBackoffMs;
}
public Integer getHeartbeatIntervalMs() {
return heartbeatIntervalMs;
}
/**
* The expected time between heartbeats to the consumer coordinator when using Kafka's group management facilities.
* Heartbeats are used to ensure that the consumer's session stays active and to facilitate rebalancing when new
* consumers join or leave the group. The value must be set lower than session.timeout.ms, but typically should be
* set no higher than 1/3 of that value. It can be adjusted even lower to control the expected time for normal
* rebalances.
*/
public void setHeartbeatIntervalMs(Integer heartbeatIntervalMs) {
this.heartbeatIntervalMs = heartbeatIntervalMs;
}
public Integer getMaxPartitionFetchBytes() {
return maxPartitionFetchBytes;
}
/**
* The maximum amount of data per-partition the server will return. The maximum total memory used for a request will
* be #partitions * max.partition.fetch.bytes. This size must be at least as large as the maximum message size the
* server allows or else it is possible for the producer to send messages larger than the consumer can fetch. If
* that happens, the consumer can get stuck trying to fetch a large message on a certain partition.
*/
public void setMaxPartitionFetchBytes(Integer maxPartitionFetchBytes) {
this.maxPartitionFetchBytes = maxPartitionFetchBytes;
}
public Integer getSessionTimeoutMs() {
return sessionTimeoutMs;
}
/**
* The timeout used to detect failures when using Kafka's group management facilities.
*/
public void setSessionTimeoutMs(Integer sessionTimeoutMs) {
this.sessionTimeoutMs = sessionTimeoutMs;
}
public Integer getMaxPollRecords() {
return maxPollRecords;
}
/**
* The maximum number of records returned in a single call to poll()
*/
public void setMaxPollRecords(Integer maxPollRecords) {
this.maxPollRecords = maxPollRecords;
}
public Long getPollTimeoutMs() {
return pollTimeoutMs;
}
/**
* The timeout used when polling the KafkaConsumer.
*/
public void setPollTimeoutMs(Long pollTimeoutMs) {
this.pollTimeoutMs = pollTimeoutMs;
}
public Integer getMaxPollIntervalMs() {
return maxPollIntervalMs;
}
/**
* The maximum delay between invocations of poll() when using consumer group management. This places an upper bound
* on the amount of time that the consumer can be idle before fetching more records. If poll() is not called before
* expiration of this timeout, then the consumer is considered failed, and the group will re-balance to reassign the
* partitions to another member.
*/
public void setMaxPollIntervalMs(Integer maxPollIntervalMs) {
this.maxPollIntervalMs = maxPollIntervalMs;
}
public String getPartitionAssignor() {
return partitionAssignor;
}
/**
* The class name of the partition assignment strategy that the client will use to distribute partition ownership
* amongst consumer instances when group management is used
*/
public void setPartitionAssignor(String partitionAssignor) {
this.partitionAssignor = partitionAssignor;
}
public Integer getConsumerRequestTimeoutMs() {
return consumerRequestTimeoutMs;
}
/**
* The configuration controls the maximum amount of time the client will wait for the response of a request. If the
* response is not received before the timeout elapsed, the client will resend the request if necessary or fail the
* request if retries are exhausted.
*/
public void setConsumerRequestTimeoutMs(Integer consumerRequestTimeoutMs) {
this.consumerRequestTimeoutMs = consumerRequestTimeoutMs;
}
public Boolean getCheckCrcs() {
return checkCrcs;
}
/**
* Automatically check the CRC32 of the records consumed. This ensures no on-the-wire or on-disk corruption to the
* messages occurred. This check adds some overhead, so it may be disabled in cases seeking extreme performance.
*/
public void setCheckCrcs(Boolean checkCrcs) {
this.checkCrcs = checkCrcs;
}
public String getKeyDeserializer() {
return keyDeserializer;
}
/**
* Deserializer class for the key that implements the Deserializer interface.
*/
public void setKeyDeserializer(String keyDeserializer) {
this.keyDeserializer = keyDeserializer;
}
public String getValueDeserializer() {
return valueDeserializer;
}
/**
* Deserializer class for value that implements the Deserializer interface.
*/
public void setValueDeserializer(String valueDeserializer) {
this.valueDeserializer = valueDeserializer;
}
public SeekPolicy getSeekTo() {
return seekTo;
}
/**
* Set if KafkaConsumer should read from the beginning or the end on startup: SeekPolicy.BEGINNING: read from the
* beginning. SeekPolicy.END: read from the end.
*/
public void setSeekTo(SeekPolicy seekTo) {
this.seekTo = seekTo;
}
public ExecutorService getWorkerPool() {
return workerPool;
}
/**
* To use a custom worker pool for continue routing {@link Exchange} after kafka server has acknowledged the message
* that was sent to it from {@link KafkaProducer} using asynchronous non-blocking processing. If using this option,
* then you must handle the lifecycle of the thread pool to shut the pool down when no longer needed.
*/
public void setWorkerPool(ExecutorService workerPool) {
this.workerPool = workerPool;
}
public Integer getWorkerPoolCoreSize() {
return workerPoolCoreSize;
}
/**
* Number of core threads for the worker pool for continue routing {@link Exchange} after kafka server has
* acknowledged the message that was sent to it from {@link KafkaProducer} using asynchronous non-blocking
* processing.
*/
public void setWorkerPoolCoreSize(Integer workerPoolCoreSize) {
this.workerPoolCoreSize = workerPoolCoreSize;
}
public Integer getWorkerPoolMaxSize() {
return workerPoolMaxSize;
}
/**
* Maximum number of threads for the worker pool for continue routing {@link Exchange} after kafka server has
* acknowledged the message that was sent to it from {@link KafkaProducer} using asynchronous non-blocking
* processing.
*/
public void setWorkerPoolMaxSize(Integer workerPoolMaxSize) {
this.workerPoolMaxSize = workerPoolMaxSize;
}
public boolean isRecordMetadata() {
return recordMetadata;
}
/**
* Whether the producer should store the {@link RecordMetadata} results from sending to Kafka. The results are
* stored in a {@link List} containing the {@link RecordMetadata} metadata's. The list is stored on a header with
* the key {@link KafkaConstants#KAFKA_RECORDMETA}
*/
public void setRecordMetadata(boolean recordMetadata) {
this.recordMetadata = recordMetadata;
}
public String getInterceptorClasses() {
return interceptorClasses;
}
/**
* Sets interceptors for producer or consumers. Producer interceptors have to be classes implementing
* {@link org.apache.kafka.clients.producer.ProducerInterceptor} Consumer interceptors have to be classes
* implementing {@link org.apache.kafka.clients.consumer.ConsumerInterceptor} Note that if you use Producer
* interceptor on a consumer it will throw a class cast exception in runtime
*/
public void setInterceptorClasses(String interceptorClasses) {
this.interceptorClasses = interceptorClasses;
}
public boolean isEnableIdempotence() {
return enableIdempotence;
}
/**
* When set to 'true', the producer will ensure that exactly one copy of each message is written in the stream. If
* 'false', producer retries due to broker failures, etc., may write duplicates of the retried message in the
* stream. Note that enabling idempotence requires max.in.flight.requests.per.connection to be less than or equal to
* 5 (with message ordering preserved for any allowable value), retries to be greater than 0, and acks must be
* 'all'.
*
* Idempotence is enabled by default if no conflicting configurations are set. If conflicting configurations are set
* and idempotence is not explicitly enabled, idempotence is disabled. If idempotence is explicitly enabled and
* conflicting configurations are set, a ConfigException is thrown.
*/
public void setEnableIdempotence(boolean enableIdempotence) {
this.enableIdempotence = enableIdempotence;
}
public Integer getReconnectBackoffMaxMs() {
return reconnectBackoffMaxMs;
}
/**
* The maximum amount of time in milliseconds to wait when reconnecting to a broker that has repeatedly failed to
* connect. If provided, the backoff per host will increase exponentially for each consecutive connection failure,
* up to this maximum. After calculating the backoff increase, 20% random jitter is added to avoid connection
* storms.
*/
public void setReconnectBackoffMaxMs(Integer reconnectBackoffMaxMs) {
this.reconnectBackoffMaxMs = reconnectBackoffMaxMs;
}
@Override
public HeaderFilterStrategy getHeaderFilterStrategy() {
return headerFilterStrategy;
}
/**
* To use a custom HeaderFilterStrategy to filter header to and from the Camel message.
*/
@Override
public void setHeaderFilterStrategy(HeaderFilterStrategy headerFilterStrategy) {
this.headerFilterStrategy = headerFilterStrategy;
}
public KafkaHeaderDeserializer getHeaderDeserializer() {
return headerDeserializer;
}
/**
* Sets custom KafkaHeaderDeserializer for deserialization kafka headers values to camel headers values.
*
* @param headerDeserializer custom kafka header deserializer to be used
*/
public void setHeaderDeserializer(final KafkaHeaderDeserializer headerDeserializer) {
this.headerDeserializer = headerDeserializer;
}
public KafkaHeaderSerializer getHeaderSerializer() {
return headerSerializer;
}
/**
* Sets custom KafkaHeaderDeserializer for serialization camel headers values to kafka headers values.
*
* @param headerSerializer custom kafka header serializer to be used
*/
public void setHeaderSerializer(final KafkaHeaderSerializer headerSerializer) {
this.headerSerializer = headerSerializer;
}
/**
* Sets additional properties for either kafka consumer or kafka producer in case they can't be set directly on the
* camel configurations (e.g.: new Kafka properties that are not reflected yet in Camel configurations), the
* properties have to be prefixed with `additionalProperties.`., e.g.:
* `additionalProperties.transactional.id=12345&additionalProperties.schema.registry.url=http://localhost:8811/avro`
*/
public void setAdditionalProperties(Map additionalProperties) {
this.additionalProperties = additionalProperties;
}
public Map getAdditionalProperties() {
return additionalProperties;
}
public boolean isSynchronous() {
return synchronous;
}
public void setSynchronous(boolean synchronous) {
this.synchronous = synchronous;
}
public PollOnError getPollOnError() {
return pollOnError;
}
/**
* What to do if kafka threw an exception while polling for new messages.
*
* Will by default use the value from the component configuration unless an explicit value has been configured on
* the endpoint level.
*
* DISCARD will discard the message and continue to poll the next message. ERROR_HANDLER will use Camel's error
* handler to process the exception, and afterwards continue to poll the next message. RECONNECT will re-connect the
* consumer and try polling the message again. RETRY will let the consumer retry poll the same message again. STOP
* will stop the consumer (it has to be manually started/restarted if the consumer should be able to consume
* messages again)
*/
public void setPollOnError(PollOnError pollOnError) {
this.pollOnError = pollOnError;
}
public Long getCommitTimeoutMs() {
return commitTimeoutMs;
}
/**
* The maximum time, in milliseconds, that the code will wait for a synchronous commit to complete
*/
public void setCommitTimeoutMs(Long commitTimeoutMs) {
this.commitTimeoutMs = commitTimeoutMs;
}
public String getIsolationLevel() {
return isolationLevel;
}
/**
* Controls how to read messages written transactionally. If set to read_committed, consumer.poll() will only return
* transactional messages which have been committed. If set to read_uncommitted (the default), consumer.poll() will
* return all messages, even transactional messages which have been aborted. Non-transactional messages will be
* returned unconditionally in either mode. Messages will always be returned in offset order. Hence, in
* read_committed mode, consumer.poll() will only return messages up to the last stable offset (LSO), which is the
* one less than the offset of the first open transaction. In particular, any messages appearing after messages
* belonging to ongoing transactions will be withheld until the relevant transaction has been completed. As a
* result, read_committed
consumers will not be able to read up to the high watermark when there are in
* flight transactions. Further, when in read_committed the seekToEnd method will return the LSO
*/
public void setIsolationLevel(String isolationLevel) {
this.isolationLevel = isolationLevel;
}
public String getKerberosConfigLocation() {
return kerberosConfigLocation;
}
/**
* Location of the kerberos config file.
*/
public void setKerberosConfigLocation(String kerberosConfigLocation) {
this.kerberosConfigLocation = kerberosConfigLocation;
}
public boolean isBatching() {
return batching;
}
/**
* Whether to use batching for processing or streaming. The default is false, which uses streaming
*/
public void setBatching(boolean batching) {
this.batching = batching;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy