Bonjour,
les ORBs se basent souvent sur l'état du socket TCP pour superviser la connexion du client au serveur. Or il arrive que des déconnections réseau ne soient pas détectées tout-de-suite par l'OS. Et donc le socket trompe l'ORB en lui indiquant que la connexion est toujours OK.
Ces cas de déconnections finissent par être détectés par l'OS après par un mécanisme TCP assez long (à base de messages de contrôles ré-émis plusieurs fois à un intervalle assez long) qui par défaut prend effectivement de l'ordre de 15 min.
Il est possible de modifier la configuration de l'OS (côté client) pour réduire ce temps.
Sous Linux, cela se fait en jouant sur les paramètres kernel suivants:
- net.ipv4.tcp_syn_retries
- net.ipv4.tcp_fin_timetout
- net.ipv4.tcp_retries2
Tu peux voir leur valeur avec la commande:
sysctl net.ipv4.tcp_retries2
et les modifier avec la commande:
sysctl -w net.ipv4.tcp_retries2=xxx
Pour un temps de détection de l'ordre de la minute, diminuer la valeur de tcp_retries2 devrait suffire.
Pour plus d'info:
http://www.linux-france.org/prj/inet...l.obscure.html
Partager