Logs du client avec CentralizeTarget (Chacha server), comment flusher les logs ?

Geuwp

Contributeur
Inscrit
16 Janvier 2015
Messages
37
Reactions
1
#1
Bonjour,

Je m'amuse à trafiquer le client 2.45.6:1 et je souhaite activer le logging du client de jeu avec deux targets :
  • Le target fichier habituel: com.ankamagames.jerakine.logger.targets.FileTarget
  • Le target "Chacha server": com.ankamagames.jerakine.logger.targets.CentralizeTarget

Rien de bien compliqué jusque là. Voici mon log4as.xml correspondant :
HTML:
<logging>
  <targets>
    <target module="com.ankamagames.jerakine.logger.targets.FileTarget" />
    <target module="com.ankamagames.jerakine.logger.targets.CentralizeTarget" />
  </targets>
</logging>
Ça fonctionne plutôt bien : le fichier de logs est créé et je reçois des données sur mon serveur de logs (chacha.ankama.lan:6666 que j'ai redirigé sur 127.0.0.1:6666).

Cependant, sur le target "Chacha server", le client de jeu n'envoie que les logs jusqu'à "(DEBUG) [RegConnectionManager] init socket" qui correspond au tout début de l'initialisation du client, alors que les logs sont complets dans le fichier.
Je me suis assuré que c'était bien le client qui n'envoyait rien (en sniffant avec Wireshark) et non pas mon serveur qui lisait mal.
J'ai alors patché le client pour rajouter un _socket.flush(); après chaque _socket.writeUTF(); (ligne 37 dans com.ankamagames.jerakine.logger.targets.CentralizeTarget) et... magie, tout s'envoie correctement !

Cependant, je doute que ce soit un bug du client... je pense qu'il doit y avoir un moyen de trigger le flush (peut-être avec un raccourci clavier ?) : mais comment !?

J'ai cherché longuement mais je n'ai rien trouvé, alors je m'en remets à vous... comment puis-je flusher les logs vers mon serveur Chacha sans patcher le client ?

Merci !
 
Inscrit
18 Février 2015
Messages
228
Reactions
7
#2
tu peux avoir tout les logs client, en créant un fichier debug.txt vide là où se trouve ton fichier log4as.xml et puis quand le jeu est lancé tu fais f11.
 

tazman59

Contributeur
Inscrit
20 Decembre 2012
Messages
149
Reactions
27
#3
Pourquoi faire compliqué, quand on peut faire simple :cool:
 

Geuwp

Contributeur
Inscrit
16 Janvier 2015
Messages
37
Reactions
1
#4
tu peux avoir tout les logs client, en créant un fichier debug.txt vide là où se trouve ton fichier log4as.xml et puis quand le jeu est lancé tu fais f11.
Merci de ta réponse. Je sais déjà cela, mais je voulais vraiment arriver à faire "fonctionner" le CentralizeTarget/Chacha server...

Si quelqu'un a la réponse, je suis toujours preneur :D !
 
Inscrit
7 Juin 2017
Messages
24
Reactions
0
#5
Pourquoi tu n'essayes pas la sortie local?

Code:
<target module="com.ankamagames.jerakine.logger.targets.SOSTarget"/>
Sortie: localhost:4444
 
Haut Bas