Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

client.py ajout erreur si la partie est finie et limitation des requètes serveur avec end() #1

Merged
merged 3 commits into from
Feb 20, 2017

Conversation

david540
Copy link
Contributor

J'ai ajouté un code d'erreur dans le cas où un client fait une requète de bourse alors que la partie est finie (__notEnd())
Cependant ce code d'erreur fait un appel à fin() à chaque requète de bourse donc celà doublerait le nombre de requète au serveur pendant une partie (risque de problèmes s'il y a trop de requète au serveur).
C'est pour celà que j'ai instauré un compteur de temps local au client, afin que fin() ne fasse plus de requète au serveur, mais retourne simplement la valeur du compteur local tant que la partie n'est pas finie
Les deux erreurs possibles de désynchronisation des timers entre client/serveur ne posent pas de problème:
-Si le client est en avance, alors son timer finira avant celui du serveur et donc il y aura des requètes au serveur pendant les dernières millisecondes de la partie qui renverra le temps réel.
-Si le client est en retard, le client fera des requètes au serveur que le serveur rejettera car la partie est finie.

J'ai ajouté un code d'erreur dans le cas où un client fait une requète de bourse alors que la partie est finie (notEnd)
Cependant ce code d'erreur fait un appel à fin() à chaque requète de bourse donc celà doublerait le nombre de requète au serveur pendant une partie (risque de problèmes s'il y a trop de requète au serveur).
C'est pour celà que j'ai instauré un compteur de temps local au client, afin que fin() ne fasse plus de requète au serveur, mais retourne simplement la valeur du compteur local tant que la partie n'est pas finie
Les deux erreurs possibles de désynchronisation des timers entre client/serveur ne posent pas de problème:
Si le client est en avance, alors son timer finira avant celui du serveur et donc il y aura des requètes au serveur pendant les dernières millisecondes de la partie qui renverra le temps réel.
Si le client est en retard, le client fera des requètes au serveur que le serveur rejettera car la partie est finie.
Update client.py ajout erreur si partie finie, et limitation des requetes end() au serveur
@matthieu637
Copy link
Owner

Bonne idée, ça évite effectivement de modifier le serveur.

Par contre, il y a quelques soucis mineurs avant de pouvoir intégrer la contribution :

  • tu définis self.dureePartie mais ne l'utilise pas (j'imagine qu'il s'agit de self.tempsPartie)
  • j'ai l'impression qu'une seule nouvelle variable self suffirait plutôt qu'en avoir 2
  • le dernier else de top peut être retiré (vu que le if juste avant fait un return)

@david540
Copy link
Contributor Author

J'ai remodifié mon pull request
-En effet, c'était bien un self.tempsPartie je ne me suis pas relu
-Je pense que deux variables sont nécessaires:
Si l'on ne compte pas modifié la durée de la partie de 600 s, dans ce cas on peut enlever self.tempsPartie et remplacer cette variable par 600 partout mais le programme perdrait en flexibilité
L'autre variable self.timerInitial sert simplement à faire que tous les clients aient comme base de mesure du temps le même nombre de secondes depuis 01/01/1970 pour savoir le temps qu'il s'est écoulé depuis le top() de l'hébergeur et donc à peu près le top() du serveur
-J'ai retiré le else de top()

Autre chose :
Pour limiter la taille des listes reçues dans historiques, j'ai pensé à ajouter un dictionnaire histoAct côté client pour ne demander au serveur seulement les éléments de 'historiques[Action]' à partir de l'élément de la nième position où n=histoAct[Action].size() du client, pour ensuite que le client append() la partie manquante envoyé par le serveur
Comme ça si un programme client demande un grand nombre de fois l'historique d'une Action (ce qui est fort probable), les messages réseaux comprendront la plupart du temps 0 ou 1 message (car il aura déjà tous les élements).
Je sais quelles modifications apportés mais je suis juste bloqué sur un code java:

public Set getHistoriqueEchanges(Action a) {
return historiques.get(a);
}
je voudrais retourner simplement une liste avec les élément de historiques.get(a) à partir de la nième position
Quelque chose d'équivalent à historiques.get(a)[n:] en python
Avez vous une idée ?

@matthieu637 matthieu637 merged commit 1dc0efe into matthieu637:master Feb 20, 2017
@matthieu637
Copy link
Owner

En effet, les 2 informations sont nécessaires mais un seul champ suffit. Pour cela, on peut faire l'addition dans la méthode top au lieu de la méthode fin (76a6432). Merci pour la contribution.

Pour les contributions au serveur, il est conseillé d'utiliser l'IDE Eclipse et d'importer le projet SimBourse pour lancer le serveur en local. Il faudra alors préciser au client de se connecter en localhost.

r = Reseau('localhost', 23456) #au lieu de de r=Reseau()

Sur ta question plus précisément, c'est une bonne idée pour la fonction historique (qui ne marchera pas pour les fonctions achats et ventes). Si tu veux vraiment t'attaquer à ce problème, je te conseille d'essayer de faire tourner un serveur en local et de t'y connecter. Puis, d'ajouter un argument facultatif aux fonctions historiques, ventes et achats afin de ne pas récupérer tout l'historique ou tous les achats/ventes mais les n derniers historiques ou n premiers achats/ventes. Pour seulement enfin attaquer le problème du cache de la fonction historique.
Pour le subset : http://stackoverflow.com/questions/12962193/creating-subset-of-a-set-in-java
Soit tu transformes l'ensemble en liste puis en extrait une sous liste (peu efficace). Soit tu passes par un for pour créer la chaîne associé et break au bon moment (plus efficace mais plus moche à écrire : voir la fonction core.Marche::fin() ).

Il vaut mieux créer un nouveau pull request sur ce sujet.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants