-
concatenation trames TCP
Bonjour,
J'ai un petit problème : J'ai un programme qui envoie des trames TCP pour commander un appareil via un port, le 12000.
Pour envoyer ces trames, mon code est simple:
//byte[] bmsg
os=socket1.getOutputStream();
os.write(bmsg);
os.flush();
Or, il apparait que lorsque j'envoie beaucoup de trames les unes à la suite des autres, elles se concatènent pour n'en former plus qu'une seule (vu grace à un sniffeur réseau).
Est-ce que vous sauriez d'ou cela pourrait-il provenir?
Merci
-
Salut,
Je n'ai pas vraiment de bonne connaissance réseaux en bas-niveaux, mais étant donné qu'une socket est considéré comme un flux sur lequel on écrit (ou on lit), je ne vois rien d'anormal à cela...
Ton appareil doit pouvoir distinguer les différentes commandes via un séparateur (comme une fin de ligne par exemple).
a++
-
Oui mais les trames doivent arriver séparément (contrainte du matos qui ne gère pas le découpage de trames.
Cela n'arrive que lorsque le nombre de trames est important et que les trames sont très rapprochées dans le temps...
-
Il semblerait que la concaténation soit le résultat de l'algorithme de Nagle : http://en.wikipedia.org/wiki/Nagle's_algorithm
Ou plus communément appelé TCP_NO_DELAY. Donc la méthode setTcpNoDelay() de ta Socket devrait régler le problème :
Code:
socket.setTcpNoDelay(false);
a++
-
Bien vu et merci!;) . Les trames sont bien envoyées quelquesoit le nombre et le rapprochement des trames
Petite rectif c'est "true" qu'il faut mettre en paramètre:
"public void setTcpNoDelay(boolean valide) throws SocketException
Valide/invalide l’option TCP_NODELAY. Valider TCP_NODELAY garantit que les paquets seront expédiés aussi rapidement que possible quelle que soit leur taille. Ceci correspond à interdire la mise en œuvre de l’algorithme de Nagle qui, en simplifiant, concatène les paquets de taille réduite dans des paquets de taille supérieure avant envoi."
Pour ceux que ca intéresse : http://marine.edu.ups-tlse.fr/~torgu.../support1.html
A+