package org.infinispan.client.hotrod.impl.async;
import java.util.Properties;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
import org.infinispan.client.hotrod.impl.ConfigurationProperties;
import org.infinispan.commons.executors.ExecutorFactory;
/**
* Default implementation for {@link org.infinispan.commons.executors.ExecutorFactory} based on an {@link ThreadPoolExecutor}.
*
* @author Mircea.Markus@jboss.com
* @since 4.1
*/
public class DefaultAsyncExecutorFactory implements ExecutorFactory {
public static final String THREAD_NAME = "HotRod-client-async-pool";
public static final AtomicInteger counter = new AtomicInteger(0);
@Override
public ExecutorService getExecutor(Properties p) {
ConfigurationProperties cp = new ConfigurationProperties(p);
ThreadFactory tf = r -> {
Thread th = new Thread(r, THREAD_NAME + "-" + counter.getAndIncrement());
th.setDaemon(true);
return th;
};
return new ThreadPoolExecutor(cp.getDefaultExecutorFactoryPoolSize(), cp.getDefaultExecutorFactoryPoolSize(),
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<>(cp.getDefaultExecutorFactoryQueueSize()),
tf);
}
}