# Sentinel for jax-rs Sentinel provides filter integration to enable flow control for web requests. Add the following dependency in `pom.xml` (if you are using Maven): ```xml com.alibaba.csp sentinel-jax-rs-adapter x.y.z ``` ## SentinelJaxRsProviderFilter the `SentinelJaxRsProviderFilter` is auto activated in pure jax-rs application. For Spring web applications you can configure with Spring bean: ```java @Configuration public class FilterConfig { @Bean public SentinelJaxRsProviderFilter sentinelJaxRsProviderFilter() { return new SentinelJaxRsProviderFilter(); } } ``` ## DefaultExceptionMapper Sentinel provides DefaultExceptionMapper to map Throwable to Response(with Status.INTERNAL_SERVER_ERROR), in order to let SentinelJaxRsProviderFilter to be called and exit the sentinel entry. according to `3.3.4 Exceptions` of [jaxrs-2_1-final-spec](https://download.oracle.com/otn-pub/jcp/jaxrs-2_1-final-eval-spec/jaxrs-2_1-final-spec.pdf): >Checked exceptions and throwables that have not been mapped and cannot be thrown directly MUSTbe wrapped in a container-specific exception that is then thrown and allowed to propagate to the un-derlying container. if WebApplicationException or its subclasses is thrown, there are automated converted to Response and can enter response filter. if throw exception which is not WebApplicationException or its subclass, and not matched by custom exception mapper, then the response filter cannot be called. for this case, I thank a default exception mapper maybe introduced. according to `4.4 Exception Mapping Providers` of [jaxrs-2_1-final-spec](https://download.oracle.com/otn-pub/jcp/jaxrs-2_1-final-eval-spec/jaxrs-2_1-final-spec.pdf): >When choosing an exception mapping provider to map an exception, an implementation MUST use theprovider whose generic type is the nearest superclass of the exception. If two or more exception providers are applicable, the one with the highest priority MUST be chosen as described in Section 4.1.3. if user also provide custom exception mapper of `Throwable`, then user has the responsibility to convert it to response and then the response filter can be called. as describe in `6.7.1 exceptions` of [jaxrs-2_1-final-spec](https://download.oracle.com/otn-pub/jcp/jaxrs-2_1-final-eval-spec/jaxrs-2_1-final-spec.pdf): >A response mapped from an exception MUST be processed using the ContainerResponsefilter chain and theWriteTointerceptor chain (if an entity is present in the mapped response). ## SentinelJaxRsClientTemplate For jax-rs client, we provide `SentinelJaxRsClientTemplate` you can use it like this: ``` Response response = SentinelJaxRsClientTemplate.execute(resourceName, new Supplier() { @Override public Response get() { return client.target(host).path(url).request() .get(); } }); ``` or executeAsync like this: ``` Future future = SentinelJaxRsClientTemplate.executeAsync(resourceName, new Supplier>() { @Override public Future get() { return client.target(host).path(url).request() .async() .get(); } }); ``` When a request is blocked, Sentinel jax-rs filter will return Response with status of TOO_MANY_REQUESTS indicating the request is rejected. You can customize it by implement your own `SentinelJaxRsFallback` and register to `SentinelJaxRsConfig`.