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

Langage PHP Discussion :

microtime(true) + usleep(), benchmark bande passante incohérent.


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 3
    Points : 2
    Points
    2
    Par défaut microtime(true) + usleep(), benchmark bande passante incohérent.
    Bonjour à tous.
    Ce post pour demander de l'aide à propos d'un comportement étrange qui peut être reproduit tout le temps (apcahe2 + php5).
    Je ne sait pas si je me plante mais je vais essayer d'expliquer la finalité de la démarche:

    J'ai besoin d'envoyer des chunks de donnée binaires (par exemple 30), puis de calculer la bande passante moyenne sur ces 30 shunts en Kbit/s.
    J'additionne chaque temps d'output dans une var, ainsi que la taille de chaque chunk, puis je fait le total à la fin.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    	<?php
     
    	// build my binary chunk
    	$var= '';
    	$o=9000;
    	while($o--)
    	{
    		$var.= "testtest";
    	}
     
    	// get the size, prepare the memory.
    	$size = strlen($var);
    	$tt_sent = 0;
    	$tt_time = 0;
     
    	// I send my chunk 30 times
    	for ($i = 0; $i < 30; $i++)
    	{
    		// start time
    		$t = microtime(true);
    		echo $var."\n";
    		ob_flush();
    		flush();
    		$e = microtime(true);
    		// end time
    		// the difference should reprenent what it takes to the server to 
    		// transmit chunk to client right ?
     
    		// add this chuck bench to the total
    		$tt_time += round($e-$t,4);
    		$tt_sent += $size;
    	}
     
    	// total result
    	echo "\n total: ".(($tt_sent*8)/($tt_time)/1024)."\n";
     
    	?>

    Dans l'exemple du dessus, ça semble marcher, mes résultats sont cohérents lorsque je limite ma bande passante sur le port 80.

    Maintenant, supposons que j'ai besoin de limiter l'envoi de ces chunks ( car le client à assez de data à traiter avec un shunts sur une seconde ).

    J'utilise usleep(1000000), ainsi, après l'envoit d'un chunk puis l'estimation du temps que cela à pris, je fait une petite pause.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    	<?php
     
    	// build my binary chunk
    	$var= '';
    	$o=9000;
    	while($o--)
    	{
    		$var.= "testtest";
    	}
     
    	// get the size, prepare the memory.
    	$size = strlen($var);
    	$tt_sent = 0;
    	$tt_time = 0;
     
    	// I send my chunk 30 times
    	for ($i = 0; $i < 30; $i++)
    	{
    		// start time
    		$t = microtime(true);
    		echo $var."\n";
    		ob_flush();
    		flush();
    		$e = microtime(true);
    		// end time
    		// the difference should reprenent what it takes to the server to 
    		// transmit chunk to client right ?
     
    		// add this chuck bench to the total
    		$tt_time += round($e-$t,4);
    		$tt_sent += $size;
     
    		usleep(1000000); // the usleep
    	}
     
    	// total result
    	echo "\n total: ".(($tt_sent*8)/($tt_time)/1024)."\n";
     
    	?>
    Dans l'exemple ci-dessus, mon calcul final est tout bonnement incohérent, j'ai des saut de 70000Kbit/s, à + d'un millions, car l'estimation du temps d'output est complètement falsifiée : (le temps calculé (microtime(true)) d'envoi de chaque chunk devient ridiculement court, même avec des données binaires plus importantes).

    J'ai besoin d'aide pour comprendre ce qu'il va pas dans cet exemple, ou si c'est un comportement normal (ob_flush();/flush(); asynchrones …)

    Config: LAMP php 5.3


    Merci !

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tes microtime() correspondent a des temps de traitement PHP, tu ne mesures pas le temps jusqu'au client.

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    J'avais la meme interogation.
    Cependant, lorsque la bandpassante est bridee (volontairement, NetLimiter) cote client, les valeurs sans usleep correspondent pile avec ma valeure de limite. D'autres scripts prouvent que c'est un bon moyen de mesurer une bande passante disponible. C'est l'introduction des usleep qui change la donne.

    Il y a surement quelque chose que j'ai pas compris (de fondamental).

    Merci !

    Nunja

Discussions similaires

  1. Serveur dedié et bande passante ?
    Par ShinJava dans le forum Hébergement
    Réponses: 9
    Dernier message: 03/06/2005, 10h29
  2. [Stratégie] Limiter la bande passante
    Par Neuromancer dans le forum Développement
    Réponses: 7
    Dernier message: 17/01/2005, 15h29
  3. Appication Client/serveur : Limiter la bande passante ?
    Par souch dans le forum Web & réseau
    Réponses: 8
    Dernier message: 25/07/2004, 14h53
  4. Limiter la bande passante
    Par naili dans le forum Réseau
    Réponses: 3
    Dernier message: 15/01/2004, 08h21
  5. [Bande passante]
    Par Alexr dans le forum Développement
    Réponses: 7
    Dernier message: 12/09/2003, 14h36

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