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

Get the Edge with a Professional Java IDE. 30-day free trial.

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.

Get the Java IDE that understands code & makes developing enjoyable. Level up your code with IntelliJ IDEA. Download the free trial.

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 }}