web-dev-qa-db-fra.com

Définition du délai de requête pour l'API client JAX-RS 2.0

J'ai écrit une simple classe de client de service Web REST qui utilise l'API client JAX-RS 2.0 pour effectuer des requêtes REST. J'essaie de comprendre comment définir un délai d'attente de demande pour chaque invocation. Voici le code pour une demande:

Client client = ClientBuilder.newBuilder().build();
WebTarget resourceTarget = client.target(restServiceUrl)
        .path("{regsysID}/{appointmentID}/")
        .resolveTemplate("regsysID", regSysId)
        .resolveTemplate("appointmentID", apptId);

Invocation invocation = resourceTarget.request(MediaType.APPLICATION_JSON).buildPut(null);
String createSessionJson = invocation.invoke(String.class);
20
sarabdeep singh

Vous pouvez le faire en créant d'abord un ClientConfig et en le fournissant comme argument lors de la création du nouveau client.

import org.glassfish.jersey.client.ClientProperties;

ClientConfig configuration = new ClientConfig();
configuration.property(ClientProperties.CONNECT_TIMEOUT, 1000);
configuration.property(ClientProperties.READ_TIMEOUT, 1000);
Client client = ClientBuilder.newClient(configuration);
13
Jeroen

Avec Resteasy, cela peut être accompli en construisant votre client en tant que tel.

Client client = new ResteasyClientBuilder()
    .establishConnectionTimeout(2, TimeUnit.SECONDS)
    .socketTimeout(2, TimeUnit.SECONDS)
    .build();

Je n'ai pas vu la liste des propriétés de configuration standard que vous pouvez définir via ClientBuilder.newClient(Configuration configuration) et qui seraient nécessaires pour rendre ce système portable.

10
codylerum

Remarque: il s'agit d'une nouvelle méthode disponible sur JAX-RS 2.1

Ceci est un très vieux message mais le code ci-dessous fonctionnera aussi bien pour Jersey que pour Resteasy.

ClientBuilder clientBuilder = ClientBuilder.newBuilder();
clientBuilder.connectTimeout(10, TimeUnit.SECONDS);
clientBuilder.readTimeout(12, TimeUnit.SECONDS);
Client client = clientBuilder.build();
10
Pravat

Tout d’abord, vous devez ajouter les dépendances pertinentes (voici pour le WildFly 10.1):

<dependency>
    <groupId>org.Apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
    <version>4.5</version>
    <scope>provided</scope>
</dependency>
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-client</artifactId>
    <version>3.0.14.Final</version>
    <scope>provided</scope>
</dependency>

Suivant - Créez un Apache HttpClient normal et transmettez-le à RestEasy Enginge en surchargeant une méthode, ce qui pose le problème suivant:

// create here a normal Apache HttpClient with all parameters, that you need
HttpClient httpClient = createHttpClient(connectTimeout,
                                         socketTimeout,
                                         connectionRequestTimeout,
                                         maxTotalHTTPConnections);
// Deprecated Apache classes cleanup https://issues.jboss.org/browse/RESTEASY-1357
// Client Framework not honoring connection timeouts Apache Client 4.3 https://issues.jboss.org/browse/RESTEASY-975
ApacheHttpClient4Engine engine = new ApacheHttpClient4Engine(httpClient) {
        @Override
        protected void loadHttpMethod(ClientInvocation request, HttpRequestBase httpMethod) throws Exception {
            super.loadHttpMethod(request, httpMethod);
            httpMethod.setParams(new BasicHttpParams());
        }
    };

return new ResteasyClientBuilder().httpEngine(engine).build();

Jetez un coup d'œil à https://issues.jboss.org/browse/RESTEASY-975 Il semble que le problème ait été résolu dans la version 3.1.0.Final. 

4
Maxim Karavaev

Pour les personnes bloquées avec une ancienne API JAX-RS 2.0 et une ancienne implémentation Resteasy, vous pouvez utiliser cette méthode:

Client client = new ResteasyClientBuilder()             
     .establishConnectionTimeout(3, TimeUnit.SECONDS)
     .socketTimeout(5, TimeUnit.SECONDS).build();

Malgré son nom, socketTimeout signifie "délai de lecture", car "docs" signifie "délai d’attente pour les données".

0
dliber