Over a million developers have joined DZone.
{{announcement.body}}
{{announcement.title}}

Asynchronous Communication With JAX-RS 2

DZone's Guide to

Asynchronous Communication With JAX-RS 2

See how you can easily set up asynchronous communication using JAX-RS 2. This code snippet will show you how it's done.

· Java Zone ·
Free Resource

Download Microservices for Java Developers: A hands-on introduction to frameworks and containers. Brought to you in partnership with Red Hat.

Asynchronous communication has become more important nowadays, especially as data become more voluminous every day. 

One of the simplest cool new features in JAX-RS 2 is asynchronous processing. What's really nice is that async processing has been added both to client and server side APIs.

For instance:

@Path("/test/operation")
@Stateless
public class TestResource {
    @GET 
    @Produce("application/json")
    @Asynchronous
    public void operation(@Suspended AsyncResponse asyncResponse) {
        asyncResponse.resume(someLongOperation()) 
    }
} 

There are two key annotations used here.


@Asynchronous: This informs the container to release client requests and start processing other incoming requests. When the worker finishes, the processing method will call the container to send the result to the client.

@Suspended: This informs the container to suspend and resume communication while the worker thread, someLongOperaton in this case, is finished.

At the client side, we could also use InvocationCallback.

Download Building Reactive Microservices in Java: Asynchronous and Event-Based Application Design. Brought to you in partnership with Red Hat

Topics:
java ,jax-rs 2 ,async ,api

Published at DZone with permission of

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}