Skip to content

Latest commit

 

History

History
 
 

riptide-faults

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Riptide: Faults

Light bulb

Javadoc Maven Central

Transient fault: a fault that is no longer present if power is disconnected for a short time and then restored

Riptide: Faults helps to classify exceptions into persistent and transient faults.

Features

  • exception classification
  • easier exception handling, e.g. for retries
  • reusable

Dependencies

  • Riptide: Core

Installation

Add the following dependency to your project:

<dependency>
    <groupId>org.zalando</groupId>
    <artifactId>riptide-faults</artifactId>
    <version>${riptide.version}</version>
</dependency>

Configuration

A very common usage is to register the transientFaults predicate with a Failsafe retry policy:

new RetryPolicy<>()
    .handleIf(TransientFaults.transientFaults());

Defaults

The TransientFaults predicates define defaults for transient fault classification. Apart from transientFaults there are the more fine-grained transientConnectionFaults and transientSocketFaults:

Connection faults

Transient connections faults happen before any request is either made, send or received by the server. Those faults can safely be retried, regardless of the actual request being made, since the server never had a chance to handle it:

new RetryRequestPolicy(
        new RetryPolicy<>()
            .handleIf(TransientFaults.transientConnectionFaults()))
    .withPredicate(alwaysTrue());

The default considers the following exceptions to be transient connection faults:

Socket faults

Transient socket faults happen after a request was (at least potentially) received by a server. Those faults should only be retried if the request is idempotent:

new RetryRequestPolicy(
        new RetryPolicy<>()
            .handleIf(TransientFaults.transientSocketFaults()))
    .withPredicate(new IdempotencyPredicate()); // the default

The default considers the following exceptions to be transient socket faults:

Customization

In order to customize this you can use any of the existing TransientFaults.Rules as a blueprint and build customized predicates:

Predicate<Throwable> predicate = TransientFaults.combine(
    ClassificationStrategy.causalChain(),
    TransientFaults.Rules.transientFaultRules()
        .exclude(SomeSpecialIOException.class::isInstance)
);

The default predicates inspect the whole causal chain of an exception. This behavior can be changed by specifying a different ClassificationStrategy:

  • causalChain(): The exception itself including all causes
  • rootCause(): The exception's root cause
  • self(): The exception itself

Getting Help

If you have questions, concerns, bug reports, etc., please file an issue in this repository's Issue Tracker.

Getting Involved/Contributing

To contribute, simply make a pull request and add a brief description (1-2 sentences) of your addition or change. For more details, check the contribution guidelines.