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

io.reactivex.netty.client.ConnectionPoolBuilder Maven / Gradle / Ivy

There is a newer version: 0.3.18
Show newest version
/*
 * Copyright 2014 Netflix, Inc.
 *
 * Licensed 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 io.reactivex.netty.client;

import io.reactivex.netty.channel.RxDefaultThreadFactory;
import io.reactivex.netty.metrics.MetricEventsSubject;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;

/**
 * A builder for creating instances of {@link ConnectionPool}
 *
 * @author Nitesh Kant
 */
public class ConnectionPoolBuilder {

    private static final ScheduledExecutorService SHARED_IDLE_CLEANUP_SCHEDULER =
            Executors.newScheduledThreadPool(1, new RxDefaultThreadFactory("global-client-idle-conn-cleanup-scheduler"));

    private final RxClient.ServerInfo serverInfo;
    private final MetricEventsSubject> eventsSubject;
    private ClientConnectionFactory> connectionFactory;
    private ClientChannelFactory channelFactory; // Nullable
    private PoolLimitDeterminationStrategy limitDeterminationStrategy = new MaxConnectionsBasedStrategy();
    private ScheduledExecutorService poolIdleCleanupScheduler = SHARED_IDLE_CLEANUP_SCHEDULER;
    private long idleConnectionsTimeoutMillis = PoolConfig.DEFAULT_CONFIG.getMaxIdleTimeMillis();

    public ConnectionPoolBuilder(RxClient.ServerInfo serverInfo, ClientChannelFactory channelFactory,
                                 MetricEventsSubject> eventsSubject) {
        this(serverInfo, channelFactory, new PooledConnectionFactory(PoolConfig.DEFAULT_CONFIG, eventsSubject),
             eventsSubject);
    }

    public ConnectionPoolBuilder(RxClient.ServerInfo serverInfo, ClientChannelFactory channelFactory,
                                 ClientConnectionFactory> connectionFactory,
                                 MetricEventsSubject> eventsSubject) {
        if (null == serverInfo) {
            throw new NullPointerException("Server info can not be null.");
        }
        if (null == channelFactory) {
            throw new NullPointerException("Channel factory can not be null.");
        }
        if (null == connectionFactory) {
            throw new NullPointerException("Connection factory can not be null.");
        }
        this.eventsSubject = eventsSubject;
        this.serverInfo = serverInfo;
        this.connectionFactory = connectionFactory;
        this.channelFactory = channelFactory;
    }

    public ConnectionPoolBuilder withMaxConnections(int maxConnections) {
        limitDeterminationStrategy = new MaxConnectionsBasedStrategy(maxConnections);
        return this;
    }

    public ConnectionPoolBuilder withIdleConnectionsTimeoutMillis(long idleConnectionsTimeoutMillis) {
        this.idleConnectionsTimeoutMillis = idleConnectionsTimeoutMillis;
        return this;
    }

    public ConnectionPoolBuilder withConnectionPoolLimitStrategy(PoolLimitDeterminationStrategy strategy) {
        limitDeterminationStrategy = strategy;
        return this;
    }

    public ConnectionPoolBuilder withPoolIdleCleanupScheduler(ScheduledExecutorService poolIdleCleanupScheduler) {
        this.poolIdleCleanupScheduler = poolIdleCleanupScheduler;
        return this;
    }

    public ConnectionPoolBuilder withNoIdleConnectionCleanup() {
        poolIdleCleanupScheduler = null;
        return this;
    }

    public ConnectionPoolBuilder withChannelFactory(ClientChannelFactory factory) {
        channelFactory = factory;
        return this;
    }

    public ConnectionPoolBuilder withConnectionFactory(ClientConnectionFactory> factory) {
        connectionFactory = factory;
        return this;
    }

    public ClientChannelFactory getChannelFactory() {
        return channelFactory;
    }

    public ClientConnectionFactory> getConnectionFactory() {
        return connectionFactory;
    }

    /**
     * Creates a new instance of the {@link ConnectionPool} if it is configured to do so.
     *
     * @return A new instance of {@link ConnectionPool} if configured, else {@code null}
     */
    public ConnectionPool build() {
        PoolConfig poolConfig = new PoolConfig(idleConnectionsTimeoutMillis);

        return new ConnectionPoolImpl(serverInfo, poolConfig, limitDeterminationStrategy, poolIdleCleanupScheduler,
                                            connectionFactory, channelFactory, eventsSubject);
    }

    public ConnectionPoolBuilder copy(RxClient.ServerInfo serverInfo) {
        ConnectionPoolBuilder copy = new ConnectionPoolBuilder(serverInfo, channelFactory, connectionFactory,
                                                                           eventsSubject);
        copy.withIdleConnectionsTimeoutMillis(idleConnectionsTimeoutMillis)
            .withPoolIdleCleanupScheduler(poolIdleCleanupScheduler)
            .withConnectionPoolLimitStrategy(limitDeterminationStrategy);

        return copy;
    }

    public long getIdleConnectionsTimeoutMillis() {
        return idleConnectionsTimeoutMillis;
    }

    public PoolLimitDeterminationStrategy getLimitDeterminationStrategy() {
        return limitDeterminationStrategy;
    }

    public ScheduledExecutorService getPoolIdleCleanupScheduler() {
        return poolIdleCleanupScheduler;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy