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

Verify, standardize, and correct the Big 4 + more– name, email, phone and global addresses – try our Data Quality APIs now at Melissa Developer Portal!

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.

Developers! Quickly and easily gain access to the tools and information you need! Explore, test and combine our data quality APIs at Melissa Developer Portal – home to tools that save time and boost revenue. 

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