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

org.redisson.api.TransactionOptions Maven / Gradle / Ivy

/**
 * Copyright 2018 Nikita Koksharov
 *
 * 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 org.redisson.api;

import java.util.concurrent.TimeUnit;

/**
 * Configuration for Transaction.
 * 
 * @author Nikita Koksharov
 *
 */
public class TransactionOptions {
    
    private long responseTimeout = 3000;
    private int retryAttempts = 3;
    private long retryInterval = 1500;

    private long syncTimeout = 5000;
    
    private long timeout = 5000;

    private TransactionOptions() {
    }
    
    public static TransactionOptions defaults() {
        return new TransactionOptions();
    }
    
    public long getResponseTimeout() {
        return responseTimeout;
    }

    /**
     * Defines timeout for Redis response. 
     * Starts to countdown when transaction has been successfully sent.
     * 

* Default is 3000 milliseconds * * @param timeout value * @param unit value * @return self instance */ public TransactionOptions responseTimeout(long timeout, TimeUnit unit) { this.responseTimeout = unit.toMillis(timeout); return this; } public int getRetryAttempts() { return retryAttempts; } /** * Defines attempts amount to send transaction * if it hasn't been sent already. *

* Default is 3 attempts * * @param retryAttempts value * @return self instance */ public TransactionOptions retryAttempts(int retryAttempts) { this.retryAttempts = retryAttempts; return this; } public long getRetryInterval() { return retryInterval; } /** * Defines time interval for each attempt to send transaction * if it hasn't been sent already. *

* Default is 1500 milliseconds * * @param retryInterval - time interval * @param retryIntervalUnit - time interval unit * @return self instance */ public TransactionOptions retryInterval(long retryInterval, TimeUnit retryIntervalUnit) { this.retryInterval = retryIntervalUnit.toMillis(retryInterval); return this; } /** * Synchronization data timeout between Redis master participating in transaction and its slaves. *

* Default is 5000 milliseconds * * @param syncTimeout - synchronization timeout * @param syncUnit - synchronization timeout time unit * @return self instance */ public TransactionOptions syncSlavesTimeout(long syncTimeout, TimeUnit syncUnit) { this.syncTimeout = syncUnit.toMillis(syncTimeout); return this; } public long getSyncTimeout() { return syncTimeout; } public long getTimeout() { return timeout; } /** * If transaction hasn't been committed within timeout it will rollback automatically. * Set -1 to disable. *

* Default is 5000 milliseconds * * @param timeout in milliseconds * @param timeoutUnit timeout time unit * @return self instance */ public TransactionOptions timeout(long timeout, TimeUnit timeoutUnit) { if (timeout == -1) { this.timeout = timeout; return this; } this.timeout = timeoutUnit.toMillis(timeout); return this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy