IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Services Web Java Discussion :

CXF "Read timed out" et "Could not send message


Sujet :

Services Web Java

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2010
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2010
    Messages : 1
    Points : 7
    Points
    7
    Par défaut CXF "Read timed out" et "Could not send message


    Nous avons passé, avec les collègues, quelque heures à comprendre ce qui se passait sur bug qui se traduisait par des temps de réponses et des ko pour non réponse, lors d'appel de webServices en production.

    Le problème est identifié et comme ma recherche sur développez.net n'a pas donné de résultat je me suis dis que ce ne serait pas mal de le documenter pour les autres.

    OBJET
    Dans un cadre d’appel http, si l’on utilise le Framework CXF, quelques précautions sont à prendre dans la configuration du client afin d’éviter un comportement du client pouvant générer des incidents de production.
    Ceci notamment si l’on doit authentifier les appels.

    CONSTAT
    Lors d’appels HTTP vers des WebServices, on constate que certains appels n’aboutissent pas et tombent en « TimeOut » client pour non réponse du WebService distant.
    Le WebService distant semble anormalement long ou en « stalled ».
    Les fichiers de log client indiquent une SocketTimeoutException en Read timed out
    La survenance du bug est aléatoire.

    ANALYSE
    • Traces applicatives et log

    En prenant une trace applicative sur le client on constate que la requête est correctement construite sur CXF mais qu’ensuite la succession des paquets envoyés est incomplète avant le déclanchement du SocketTimeoutException.
    Les fichiers de logs client n’apportent pas plus d’informations que les piles d’exceptions du timeout.
    Les fichiers de logs Serveur montrent bien l’arrivée de la requête mais sans complétion, puis notent une fermeture de session tcp client.
    On peut déterminer qu’il s’agit bien d’un TimeOut prononcé par le client pour non réponse du serveur alors que le serveur attend la complétion de la requête.
    • Traces réseau

    CLIENT :
    La trace du réseau coté client permet de constater que le timeout prononcé correspond à chaque fois à une même caractéristique et forme de bug.
    La session TCP est correctement et rapidement ouverte, les acquittements sont corrects.
    Le dysfonctionnement est caractérisé par l’émission d’une commande HTTP POST sans poursuite par l’émission du BODY HTTP accompagnant le POST.

    A l’issue de la durée de Timeout (60s) on constate une fin de session TCP émise (FIN ACK)
    SERVEUR :
    On constate bien l’arrivée du POST à T0 après ouverture rapide de session TCP.
    Le serveur se met en attente de réception du BODY.
    A l’issue de la durée de Timeout (60s) on constate une fin de session TCP demandée par le client (FIN ACK) et on acquitte la demande de fin de session.

    En fait la documentation du client pour le Framework CXF indique une incompatibilité entre les options :
    • Transfer encoding = chunked
    Et
    • Basic Authentication

    Comme l’option de Transfer encoding est positionnée par défaut il est nécessaire de la configurer à « false ».

    CORRECTION

    Pour utiliser le Framework CXF dans un contexte d’appel authentifié, il faut configurer explicitement certaines options du bus et du conduit http.
    Dans ce cas de figure, il faut impérativement configurer dans le conduit, l’option du client AllowChunking= “false“ de façon explicite.

    Cela résout complètement le bug de communication du POST sans le BODY, donc un appel de WebService sans l’enveloppe soap produisant un ko.

    Exemple de configuration :

    http://cxf.apache.org/docs/client-ht...l-support.html
    • Chapitre « The client element », attribut « AllowChunking »

    Dans une config CXF client chargée par l’appli :

    <!-- parametrage du conduit HTTP -->
    <http:conduit name="*.http-conduit">
    <http:client ReceiveTimeout="${webservice.client.timeout.receive}" ConnectionTimeout="${webservice.client.timeout.connexion}" AllowChunking="false" />
    </http:conduit>
    LIENS ET FORUMS





  2. #2
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Octobre 2015
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte de système d'information
    Secteur : Finance

    Informations forums :
    Inscription : Octobre 2015
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Merci !
    5 ans plus tard, toujours d'actualité.

  3. #3
    Membre éclairé
    Homme Profil pro
    Consultant Angular / Java J2EE
    Inscrit en
    Novembre 2008
    Messages
    545
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Luxembourg

    Informations professionnelles :
    Activité : Consultant Angular / Java J2EE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2008
    Messages : 545
    Points : 875
    Points
    875
    Par défaut
    Merci pour cette note très complète !
    8 ans plus tard c'est également toujours d'actualité :p
    N'oubliez pas avant de poster :

Discussions similaires

  1. java.net.SocketTimeoutException: Read timed out
    Par riadhhwajdii dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 22/12/2009, 14h15
  2. [WS 2003] "Read Time Out" pour fichier>8M
    Par jerbo dans le forum Windows Serveur
    Réponses: 0
    Dernier message: 24/07/2009, 16h05
  3. JAX-WS Applet vers webservice dotnet, SocketTimeoutException Read timed out
    Par maitredede dans le forum API standards et tierces
    Réponses: 0
    Dernier message: 07/05/2009, 14h38
  4. [Web Service] socket timeout : read timed out
    Par AlexC3301 dans le forum Bibliothèques et frameworks
    Réponses: 3
    Dernier message: 29/04/2009, 00h51
  5. perl read timed-out
    Par damsdu77 dans le forum Programmation et administration système
    Réponses: 2
    Dernier message: 29/07/2008, 17h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo