Kuan Po Tseng created KAFKA-19264:
-------------------------------------

             Summary: Remove fallback for thread pool sizes in 
RemoteLogManagerConfig
                 Key: KAFKA-19264
                 URL: https://issues.apache.org/jira/browse/KAFKA-19264
             Project: Kafka
          Issue Type: Task
          Components: Tiered-Storage
            Reporter: Kuan Po Tseng
            Assignee: Kuan Po Tseng


The fallback mechanism was first introduced in 
[KIP-950|https://cwiki.apache.org/confluence/x/joqzDw]. According to the 
proposal, if no thread values are set for 
{{remote.log.manager.copier.thread.pool.size}} and 
{{{}remote.log.manager.expiration.thread.pool.size{}}}, these two configs would 
default to using the value of {{{}remote.log.manager.thread.pool.size{}}}.

As quoted from the KIP:
{quote}If no thread values are set for the two new configurations presented 
later on in the document we will default to using the same number of threads in 
each pool as detailed by remote.log.manager.thread.pool.size.
{quote}
This fallback behavior was implemented in 
[https://github.com/apache/kafka/commit/84ab3b9a5c4930f5ae047df088e38c456c7cde54].

However, this approach was abandoned in 
[KIP-1030|https://cwiki.apache.org/confluence/x/FAqpEQ], where the default 
values for {{copier}} and {{expiration}} thread pool sizes were changed from 
{{-1}} to {{{}10{}}}. The related commit can be found in 
[https://github.com/apache/kafka/commit/3b1bd3812e48d488e4b6b53a9085d6552e8adf02].

Additionally, both {{remote.log.manager.copier.thread.pool.size}} and 
{{remote.log.manager.expiration.thread.pool.size}} now include a configuration 
validator that enforces a minimum value of {{{}1{}}}. This means the fallback 
mechanism should be removed from 
[{{RemoteLogManagerConfig.java}}|https://issues.apache.org/jira/issues/RemoteLogManagerConfig.java]
 to align with the new defaults and validation.

In short, RemoteLogManagerConfig should apply the following changes:
{code:java}
     public int remoteLogManagerCopierThreadPoolSize() {
-        int size = 
config.getInt(REMOTE_LOG_MANAGER_COPIER_THREAD_POOL_SIZE_PROP);
-        return size == -1 ? remoteLogManagerThreadPoolSize() : size;
+        return config.getInt(REMOTE_LOG_MANAGER_COPIER_THREAD_POOL_SIZE_PROP);
     }

     public int remoteLogManagerExpirationThreadPoolSize() {
-        int size = 
config.getInt(REMOTE_LOG_MANAGER_EXPIRATION_THREAD_POOL_SIZE_PROP);
-        return size == -1 ? remoteLogManagerThreadPoolSize() : size;
+        return 
config.getInt(REMOTE_LOG_MANAGER_EXPIRATION_THREAD_POOL_SIZE_PROP);
     }{code}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to