All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.kafka.clients.consumer.internals.FetchConfig Maven / Gradle / Ivy

There is a newer version: 3.7.0
Show newest version
/*
 * 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.kafka.clients.consumer.internals;

import org.apache.kafka.clients.consumer.Consumer;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.common.IsolationLevel;
import org.apache.kafka.common.serialization.Deserializer;

import java.util.Objects;

/**
 * {@link FetchConfig} represents the static configuration for fetching records from Kafka. It is simply a way
 * to bundle the immutable settings that were presented at the time the {@link Consumer} was created for later use by
 * classes like {@link Fetcher}, {@link CompletedFetch}, etc.
 *
 * 

* * In most cases, the values stored and returned by {@link FetchConfig} will be those stored in the following * {@link ConsumerConfig consumer configuration} settings: * *

    *
  • {@link #minBytes}: {@link ConsumerConfig#FETCH_MIN_BYTES_CONFIG}
  • *
  • {@link #maxBytes}: {@link ConsumerConfig#FETCH_MAX_BYTES_CONFIG}
  • *
  • {@link #maxWaitMs}: {@link ConsumerConfig#FETCH_MAX_WAIT_MS_CONFIG}
  • *
  • {@link #fetchSize}: {@link ConsumerConfig#MAX_PARTITION_FETCH_BYTES_CONFIG}
  • *
  • {@link #maxPollRecords}: {@link ConsumerConfig#MAX_POLL_RECORDS_CONFIG}
  • *
  • {@link #checkCrcs}: {@link ConsumerConfig#CHECK_CRCS_CONFIG}
  • *
  • {@link #clientRackId}: {@link ConsumerConfig#CLIENT_RACK_CONFIG}
  • *
  • {@link #keyDeserializer}: {@link ConsumerConfig#KEY_DESERIALIZER_CLASS_CONFIG}
  • *
  • {@link #valueDeserializer}: {@link ConsumerConfig#VALUE_DESERIALIZER_CLASS_CONFIG}
  • *
  • {@link #isolationLevel}: {@link ConsumerConfig#ISOLATION_LEVEL_CONFIG}
  • *
* * However, there are places in the code where additional logic is used to determine these fetch-related configuration * values. In those cases, the values are calculated outside of this class and simply passed in when constructed. * *

* * Note: the {@link Deserializer deserializers} used for the key and value are not closed by this class. They should be * closed by the creator of the {@link FetchConfig}. * * @param Type used to {@link Deserializer deserialize} the message/record key * @param Type used to {@link Deserializer deserialize} the message/record value */ public class FetchConfig { final int minBytes; final int maxBytes; final int maxWaitMs; final int fetchSize; final int maxPollRecords; final boolean checkCrcs; final String clientRackId; final Deserializer keyDeserializer; final Deserializer valueDeserializer; final IsolationLevel isolationLevel; public FetchConfig(int minBytes, int maxBytes, int maxWaitMs, int fetchSize, int maxPollRecords, boolean checkCrcs, String clientRackId, Deserializer keyDeserializer, Deserializer valueDeserializer, IsolationLevel isolationLevel) { this.minBytes = minBytes; this.maxBytes = maxBytes; this.maxWaitMs = maxWaitMs; this.fetchSize = fetchSize; this.maxPollRecords = maxPollRecords; this.checkCrcs = checkCrcs; this.clientRackId = clientRackId; this.keyDeserializer = Objects.requireNonNull(keyDeserializer, "Message key deserializer provided to FetchConfig should not be null"); this.valueDeserializer = Objects.requireNonNull(valueDeserializer, "Message value deserializer provided to FetchConfig should not be null"); this.isolationLevel = isolationLevel; } public FetchConfig(ConsumerConfig config, Deserializer keyDeserializer, Deserializer valueDeserializer, IsolationLevel isolationLevel) { this.minBytes = config.getInt(ConsumerConfig.FETCH_MIN_BYTES_CONFIG); this.maxBytes = config.getInt(ConsumerConfig.FETCH_MAX_BYTES_CONFIG); this.maxWaitMs = config.getInt(ConsumerConfig.FETCH_MAX_WAIT_MS_CONFIG); this.fetchSize = config.getInt(ConsumerConfig.MAX_PARTITION_FETCH_BYTES_CONFIG); this.maxPollRecords = config.getInt(ConsumerConfig.MAX_POLL_RECORDS_CONFIG); this.checkCrcs = config.getBoolean(ConsumerConfig.CHECK_CRCS_CONFIG); this.clientRackId = config.getString(ConsumerConfig.CLIENT_RACK_CONFIG); this.keyDeserializer = Objects.requireNonNull(keyDeserializer, "Message key deserializer provided to FetchConfig should not be null"); this.valueDeserializer = Objects.requireNonNull(valueDeserializer, "Message value deserializer provided to FetchConfig should not be null"); this.isolationLevel = isolationLevel; } @Override public String toString() { return "FetchConfig{" + "minBytes=" + minBytes + ", maxBytes=" + maxBytes + ", maxWaitMs=" + maxWaitMs + ", fetchSize=" + fetchSize + ", maxPollRecords=" + maxPollRecords + ", checkCrcs=" + checkCrcs + ", clientRackId='" + clientRackId + '\'' + ", keyDeserializer=" + keyDeserializer + ", valueDeserializer=" + valueDeserializer + ", isolationLevel=" + isolationLevel + '}'; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy