Ves al contingut principal

PHP vs Node.js: rendiment en concurrència

Bo, doncs per motius laborals i familiars he estat un poc absent (del bloc), però ja aprofitant unes proves que he fet al treball, vaig a mostrar els resultats obtesos.
En principi, com sempre li he tingut mania al javascript, pensava que seria més lent que el php, però pareix ser que l'asincronisme fa que en determinades coses vaja molt més ràpid. La prova consisteix en recorrer un parell de taules enormes (400k registres) i fer alguns càlculs. He fet les proves amb el benchmarking de apache (ab), anem a veure el codi, he obviat les consultes per simplificar:

PHP

$sql='';
$preguntesResult =  mysql_query($sql) or die('Consulta fallidaA: ' . mysql_error());

$sqlrespostes= ''
$respostesResult =  mysql_query($sqlrespostes) or die('Consulta fallidaB: ' . mysql_error());
while($line = mysql_fetch_array($preguntesResult, MYSQL_ASSOC)){
  $preguntes[]= $line;
}
foreach ($preguntes as $pregunta) {

}
$cadena = "";
while($line = mysql_fetch_array($respostesResult, MYSQL_ASSOC)){
  $respostes[] = $line;

  foreach($preguntes as $pregunta){
      $cadena .= $pregunta["id"] . ":" . $line["pregunta"] . "\n";
      //echo $cadena;
  }
}
file_put_contents("volcat1.php.txt",$cadena,FILE_APPEND);
foreach($preguntes as $pregunta){
  //
}


Node.js


var mysql = require('mysql');
var http = require('http');

function doProcess(req, res) {
  var connection = mysql.createConnection({
  });
  connection.connect();
  respostes = [];
  preguntes = [];
  sql = ';
  connection.query(sql, function(err, rows, fields) {
    if (err) throw err;
    for (i = 0; i < rows.length; i++) {
      preguntes[i] = rows[i];
    }
    for (i = 0; i < preguntes.length; i++) {

    }
    for (i = 0; i < preguntes.length; i++) {

    }
  });
  sql2 = '';
  cadena = "";
  connection.query(sql2, function(err, rows, fields) {
    if (err) throw err;
    for (i = 0; i < rows.length; i++) {
      respostes[i] = rows[i];
      for (j = 0; j < preguntes.length; j++) {        
        cadena += preguntes[j]["id"] + ":" + respostes[i]["pregunta"] + "\n";        
      }
    }
      res.writeHead(200, {
        'Content-Type': 'text/html'
      });
      res.write('Acabat');
      res.end();
    }
  });

  connection.end();
}
server = http.createServer(doProcess);
server.listen(8080);


Els resultats em van sorprender, executats a aquesta màquina:
CPU: Intel(R) Core(TM)2 Duo CPU E8400 @ 3.00GHz
RAM: 4GB 
a un lliurex 14.04 Pime, anem a fer 10000 peticions amb una concurrència de 10 simulant les peticions que anaven a fer.

Provem el benchmark php:

ab -r -n 10000 -c 10 http://localhost/benchmark1.php

i el resultat:

Server Software: Apache/2.4.10
Server Hostname: localhost
Server Port: 80

Document Path: /benchmark1.php
Document Length: 6 bytes

Concurrency Level: 10
Time taken for tests: 5123.183 seconds
Complete requests: 10000
Failed requests: 0
Total transferred: 2080000 bytes
HTML transferred: 60000 bytes
Requests per second: 1.95 [#/sec] (mean)
Time per request: 5123.183 [ms] (mean)
Time per request: 512.318 [ms] (mean, across all concurrent requests)
Transfer rate: 0.40 [Kbytes/sec] received

Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 0 0.0 0 0
Processing: 936 5123 1472.6 5331 9829
Waiting: 936 5119 1471.5 5325 9829
Total: 936 5123 1472.6 5331 9829

Percentage of the requests served within a certain time (ms)
50% 5331
66% 5901
75% 6233
80% 6392
90% 6864
95% 7272
98% 7737
99% 8073
 100% 9829 (longest request)  


És a dir, 1,42 hores en fer el test, una mitjana de 5s per petició. Ara provem el codi en node:

ab -r -n 10000 -c 10 http://localhost/:8080

i el resultat:

Server Software:        Apache/2.4.10
Server Hostname:        localhost
Server Port:            80

Document Path:          /:8080
Document Length:        278 bytes

Concurrency Level:      1000
Time taken for tests:   59.963 seconds
Complete requests:      100000
Failed requests:        698
   (Connect: 0, Receive: 206, Length: 286, Exceptions: 206)
Non-2xx responses:      99714
Total transferred:      45669012 bytes
HTML transferred:       27720492 bytes
Requests per second:    1667.70 [#/sec] (mean)
Time per request:       599.630 [ms] (mean)
Time per request:       0.600 [ms] (mean, across all concurrent requests)
Transfer rate:          743.77 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0   18 255.1      1    7016
Processing:     3  156 2055.9      9   52491
Waiting:        0  103 1720.5      8   39935
Total:          5  174 2103.1     10   52491

Percentage of the requests served within a certain time (ms)
  50%     10
  66%     10
  75%     11
  80%     11
  90%     13
  95%     16
  98%     22
  99%   1190
 100%  52491 (longest request)


Sorprenentment, i després d'esperar més d'una hora i mitja a l'enterior test, este tarda quasi un minut per a resoldre el mateix problema. Després d'un dia revisant el codi per que pareix que hi haja un error, per mi i per altra gent, i vegent i comparatnt resultats, vegem que node.js guanya en el seu terreny, és a dir, múltiples peticions concurrents. Ja que node no es bloqueja en cap cas, i en php cada petició a la base de dades és bloquejant.
Vol dir que sempre va millor node.js? Doncs supose que no, però en este cas, absolutament sí, com s'ha demostrat.

Comentaris

Entrades populars d'aquest blog

Hui he vist la por als ulls

Estic trist ,molt trist.Vinc de la manifestació del 9 d'octubre i, puc dir que he vist moltes coses, però el que no he vist és democràcia.
He vist moltes banderes d'Espanya i blaveres dels increpadors, però no he vist democràcia. Les seues paraules eren "ven aquí fuera", "te voy a meter esa bandera por el coño", etc.He vist com manifestants fàcilment identificables entraven a provocar i la Policia Nacional no feia res per evitar-ho, però no he vist democràcia. He vist com un pare utilitzava al seu fill per provocar, i amb actitud agresiva (inclús anava a pegar-li manotada a un), però no he vist democràcia.He vist com es permetia una manifestació no autoritzada que podia alterar l'ordre públic. Segons la sacrosanta Constitució Espanyola, això és il·legal, però no he vist democràcia.He vist com la Policia Nacional tractava respectuosament, i inclús es coordinava amb els feixites. A nosaltres ens miraven amb cara de fàstic, però no he vist democràcia.He vi…

Comparativa dels Sistemes Polítics Espanyol, Valencià i d'un partit polític. (II)

El Poder Executiu En l’Estat Espanyol, el poder executiu real bé donat pel President del Govern. Aquest triarà els Vicepresidents, Ministres, etc (directa o indirectament, alguns alts càrrecs els triaran els corresponent Ministres). No hi ha cap limitació al respecte la persona elegida (no ha de ser diputada, ni cap límit de formació, etc.).
Al País Valencià, l’òrgan executiu és el Consell, i, existeix, de manera anàloga, el president del Consell (què és, també, el president del Generalitat, el és conjunt d’institucions d’autogovern). S’elegix de manera anàloga al President del Govern espanyol, però amb la diferència que ha d’ésser elegit entre els diputats de les Corts Valencianes. Aquest procedirà, igual que al govern espanyol, a nomenar el seu gabinet.
Al Bloc Nacionalista Valencià, el poder executiu rau en l’Executiva Nacional. Aquesta, de manera tradicional, és triada al Congrés Nacional des d’un sistema de llista tancada majoritari. Encara que tradicionalment sol haver-hi només…

Comparativa dels Sistemes Polítics Espanyol, Valencià i d'un partit polític. (I)

Introducció Els partits polítics, intenten ser al seu funcionament un reflex del que volen per a la societat. És a dir, mantenen unes estructures de govern similars a les de la societat, establint certs paral·lelismes (llevat certes limitacions, clar).  En el present article, m’agradaria comparar el funcionament del partit a que pertany (el Bloc Nacionalista Valencià) amb el govern nacional valencià i l’estatal de Madrid.
Carta Magna En l’estat la carta magna és la Constitució Espanyola, va ser aprovada en 1978. Per a ser modificada, segons els articles calen majories reforçades (⅗ o ⅔), i un referèndum posterior. No hi ha revisió periòdica, si no ha de ser a iniciativa dels partits de Las Cortes. No és possible via Iniciativa Popular.  Ho podem trobar al Títol X. És la màxima llei legislativa. Per a l’autogovern valencià, la Carta Magna és l’Estatut d’Autonomia. Té rang de Llei Orgànica, per tant,està només un esglaó per davall de la Constitució Espanyola. Es podrà impulsar des de…