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

com.google.cloud.hadoop.gcsio.OperationWithRetry Maven / Gradle / Ivy

/**
 * Copyright 2014 Google Inc. All Rights Reserved.
 *
 *  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 com.google.cloud.hadoop.gcsio;

import com.google.api.client.util.BackOff;
import com.google.api.client.util.Sleeper;
import com.google.api.services.storage.StorageRequest;
import com.google.cloud.hadoop.util.LogUtil;
import com.google.common.base.Predicate;

import java.io.IOException;


/**
 * Implements application level operation retries.
 * @param  The StorageRequest class
 * @param  The result of the StorageRequest
 */
public class OperationWithRetry, S> {

  // Logger.
  private static final LogUtil log = new LogUtil(OperationWithRetry.class);

  private final Sleeper sleeper;
  private final BackOff backOff;
  private final T request;
  private final Predicate shouldRetryPredicate;

  public OperationWithRetry(Sleeper sleeper, BackOff backOff, T request,
      Predicate shouldRetryPredicate) {
    this.sleeper = sleeper;
    this.backOff = backOff;
    this.request = request;
    this.shouldRetryPredicate = shouldRetryPredicate;
  }

  /**
   * Execute the operation until while we have not yet completed successfully and the
   * shouldRetryPredicate returns true and the backOff has not signalled completion.
   * @return The result of the operation
   * @throws IOException If we exhaust our backOff retries or the operation throws an
   * exception we should not retry. The exception will be as was thrown by the StorageRequest's
   * execute method.
   */
  public S execute() throws IOException {
    long nextRetryBackoff;
    IOException lastException;

    do {
      try {
        return request.execute();
      } catch (IOException ioe) {
        if (shouldRetryPredicate.apply(ioe)) {
          log.debug("Retrying after catching exception", ioe);
          lastException = ioe;
          nextRetryBackoff = backOff.nextBackOffMillis();
          try {
            sleeper.sleep(nextRetryBackoff);
          } catch (InterruptedException ie) {
            throw new IOException(ie);
          }
        } else {
          log.debug("Not retrying after catching exception", ioe);
          throw ioe;
        }
      }
    } while (nextRetryBackoff != BackOff.STOP);

    log.debug("Exhausted retries. lastException was: ", lastException);
    throw lastException;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy