January 17, 2015

Reactive Jersey Client using Java 8, RxJava and Netflix Hystrix

In this post I will show you how to use Jersey Client Reactive API, it's RxJava Observable support together with Netflix Hystrix, latency and fault tolerance library. All sources are placed in GitHub jersey--examples--rx-client-java8-webapp project.

Jersey framework contains Reactive Client API. Reactive Jersey Client API is a generic API allowing end users to utilize the popular reactive programming model when using Jersey Client. Reactive programming is very popular these days. It helps you to implement asynchronous code with solved callback hell issue.


Jersey

Jersey supports RxJava ObservableJava 8 CompletionStage and CompletableFutureGuava ListenableFuture and FuturesJSR-166e CompletableFuture. It also provides SPI to be extended by custom reactive libraries.

There is excellent 3 part blog post series written by Michal Gajdoš about Reactive Jersey Client:
  1. Reactive Jersey Client – Motivation
  2. Reactive Jersey Client – Usage and Supported Reactive Libraries
  3. Reactive Jersey Client – Customization (SPI)

Jersey source code contains also examples for supported reactive libraries, see modules:


Hystrix

Hystrix is a latency and fault tolerance library designed to isolate points of access to remote systems, services and 3rd party libraries, stop cascading failure and enable resilience in complex distributed systems where failure is inevitable.

You usually use Hystrix to isolate dependent system call into HystrixCommand class. It allows to be executed synchronously, asynchronously (returns java.util.concurrent.Future) and also asynchronously via RxJava Observable.

Code

In case dependent system already supports RxJava Observable API you can use specific HystrixObservableCommand class. And thanks to Jersey Reactive Client API and its RxJava support it allows us to write resilient JAX-RS client code.

private class ForecastCommand extends HystrixObservableCommand<Forecast> {
    private final Destination destination;
    ...
    @Override
    protected Observable<Forecast> run() {
        return RxObservable.from(forecastWebTarget)
                .resolveTemplate("destination", destination.getDestination())
                .request().rx()
                .get(Forecast.class);
    }
    @Override
    protected Observable<Forecast> getFallback() {
        return Observable.just(new Forecast(destination.getDestination(), "N/A"));
    }
}

The code above creates new Hystrix RxJava Observable ready Command that invokes remote REST API using Jersey Reactive Client API. Whenever API call fails or times out a getFallback() method is invoked. And in this case we return Forecast instance with N/A forecast value.

Whole example web application enhanced by code using Hystrix is placed into my GitHub jersey--examples--rx-client-java8-webapp repository. Shown and little but simplified code snipped is from HystrixObservableAgentResource class. The example module is clone of rx-client-java8-webapp.

To run the example:
    mvn clean package jetty:run

At beginning of HystrixObservableAgentResource class there are TIMEOUT_* constants. You can play with values and you will see that sometimes you don't get all domain objects' values and sometimes you see default values (N/A for Forecast and -1 for Calculation). You can also play with Thread.sleep intervals but because of Hystrix timeout support the overall JAX-RS resource method processing time is never (too much) longer than TIMEOUT_OVERALL (currently 900 ms).

You can also check unit test RxClientsTest. Processing time is expected between 850 and 950 ms!


Links





53 comments:

  1. Ace4sure is the website that deals in preparation material for the exam for many years. According to my exposure and research, this is the right platform where you can get exact 70-486 Dumps Questions.

    ReplyDelete
  2. There's definately loads to apprehend approximately this problem. I certainly like all the factors you made guide.

    ReplyDelete
  3. Thanks for Sharing a Very Informative Post & I read Your Article & I must say that is very helpful post for us. Primavera P6 Certification Training in Chennai | Primavera Training in India

    ReplyDelete
  4. https://designingcourses.in/graphic-designing-courses-in-bangalore/

    Learn graphic designing courses in bangalore we provide best graphic designing training and 100% placement assistance

    ReplyDelete
  5. This comment has been removed by the author.

    ReplyDelete
  6. This comment has been removed by the author.

    ReplyDelete
  7. Hello Blogger,

    Pleasant Post. Gratitude for Sharing! I Believe That Individuals Should Know Exactly the Way in Which Great This Data Is in Your Article. It’s Intriguing Substance and Extraordinary Work.
    SEO Course In Surat
    < a href="https://www.simbainstitute.in/"> IT Institute In Surat

    ReplyDelete
  8. Explore the world with our World SIM Card. Your gateway to global connectivity, this card ensures you're always in touch, no matter where your adventures take you. Stay connected, share your experiences, and navigate with ease, making your journeys more memorable and hassle-free. Say goodbye to roaming worries and embrace the freedom to connect worldwide.




    ReplyDelete

  9. Quadrobits, a virtual advertising corporation, gives tailored techniques together with search engine optimization and percent to force advertising and marketing fulfillment with knowledge and clean dreams. Here at social media marketing.

    ReplyDelete
  10. Very Good Blog and nice Information.
    check our Web Design Course In Kolkata

    ReplyDelete
  11. thanks for this things, i get so much knowledge from this thankyou ekotogel

    ReplyDelete
  12. such a good things, i hope you always be a good content creator !! bisajitu

    ReplyDelete
  13. I enjoyed your post on using the Jersey Client with RxJava and Hystrix. Your explanations are clear and the code snippets are super helpful. Great job showcasing the power of reactive programming! Keep up the great work!
    bca internship | internship for bca students | sql internship | online internship for btech students | internship for 1st year engineering students

    ReplyDelete