Maison >développement back-end >tutoriel php >Testez en boucle l'efficacité de la lecture et de l'écriture php sur Redis et la mémoire partagée (shm) sous Centos

Testez en boucle l'efficacité de la lecture et de l'écriture php sur Redis et la mémoire partagée (shm) sous Centos

不言
不言original
2018-07-06 15:44:292225parcourir

Cet article présente principalement l'efficacité des tests en boucle PHP pour lire et écrire Redis et la mémoire partagée (shm) sous Centos. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer.

Redis, memcache et mémoire partagée lisent tous les données de la mémoire Afin de tester laquelle est la plus efficace, j'ai fait un test équitable sous ma machine virtuelle Centos.

Paramètres des tests

Environnement : Centos (configuration ignorée), langage : PHP, WebServer : Nginx, nombre de tests : 10000, type et longueur de caractères : string (1024 )

Préparation des tests

<?php
//测试数据
$arr = array( 1 => 
  array (&#39;id&#39; => &#39;4146&#39;,&#39;attacksdfdsfdsddddddddddd&#39; => &#39;5.45&#39;,&#39;atk_class&#39; => &#39;神圣级&#39;,&#39;wufang&#39; => &#39;4.9&#39;,&#39;def_class&#39; => &#39;超神级&#39;,&#39;cefang&#39; => &#39;4.9&#39;,&#39;mdf_class&#39; => &#39;超神级&#39;,&#39;hp&#39; => &#39;6.43&#39;,&#39;hp_class&#39; => &#39;神王级&#39;,&#39;dodge&#39; => &#39;55&#39;,&#39;dodge_class&#39; => &#39;SSSS&#39;,&#39;crit&#39; => &#39;50&#39;,&#39;crit_class&#39; => &#39;SSS&#39;,&#39;penetrate&#39; => &#39;55&#39;,&#39;penetrate_class&#39; => &#39;SSSS&#39;,&#39;mingzhong&#39; => &#39;51&#39;,&#39;hit_class&#39; => &#39;SSSS&#39;,&#39;anti_dizziness&#39; => &#39;0&#39;,&#39;anti_dizzinesssdfdsfdsfdsfdsfds_class&#39; => &#39;F&#39;,&#39;anti_critical&#39; => &#39;20&#39;,&#39;anti_critical_class&#39; => &#39;F&#39;,&#39;tenacity&#39; => &#39;0&#39;,&#39;tenacity_class&#39; => &#39;F&#39;,
  ),
  2 => 
  array (&#39;id&#39; => &#39;414ddffff7&#39;,&#39;attack&#39; => &#39;5.45&#39;,&#39;atk_class&#39; => &#39;神圣级&#39;,&#39;wufang&#39; => &#39;4.95&#39;,&#39;def_class&#39; => &#39;超神级&#39;,&#39;cefang&#39; => &#39;4.95&#39;,&#39;mdf_class&#39; => &#39;超神级&#39;,&#39;hp&#39; => &#39;6.43&#39;,&#39;hp_class&#39; => &#39;神王级&#39;,&#39;dodge&#39; => &#39;55&#39;,&#39;dodge_class&#39; => &#39;SSSS&#39;,&#39;crit&#39; => &#39;50&#39;,&#39;crit_class&#39; => &#39;SSS&#39;,&#39;penetrate&#39; => &#39;55&#39;,&#39;penetrate_class&#39; => &#39;SSSS&#39;,&#39;mingzhong&#39; => &#39;51&#39;,&#39;hit_class&#39; => &#39;SSSS&#39;,&#39;anti_dizziness&#39; => &#39;0&#39;,&#39;anti_dizziness_clsdfdsfdsfdsfdsfdsass&#39; => &#39;F&#39;,&#39;anti_critical&#39; => &#39;20&#39;,&#39;anti_critical_class&#39; => &#39;F&#39;,&#39;tenacity&#39; => &#39;0&#39;,&#39;tenacity_class&#39; => &#39;F&#39;,
  ));

$str = json_encode($arr);
echo strlen($str);          //输出1024
Effectuer 10 000 tests d'écriture sur redis

<?php
$redis = new Redis();
$redis->connect(&#39;127.0.0.1&#39;,6379);
$redis->auth(&#39;310c8cabcdefghf2d8abcdefd44496ac80&#39;);
$start = microtime(true) ;

for($i = 0; $i<10000; $i++) {
    $redis->set(&#39;key&#39;, $str);
}
echo microtime(true) - $start;    //执行5次,大概平均结果为  1.7016470432281 秒
Effectuer 10 000 écritures sur la mémoire partagée (shm) Écrire test

<?php
$key = 0x4337b123;  
$size = 1024;  
$shmid = @shmop_open($key, &#39;c&#39;, 0644, $size);  
$start = microtime(true);
for($i = 0; $i<10000; $i++) {
    shmop_write($shmid, $str, 0); 
}
@shmop_close($shmid);
echo microtime(true) - $start;  //执行5次,大概平均结果为 0.0025370121002197 秒
Effectuer 10 000 tests de lecture sur redis

<?php
$redis = new Redis();
$redis->connect(&#39;127.0.0.1&#39;,6379);
$redis->auth(&#39;310c8cabcdefghf2d8abcdefd44496ac80&#39;);
$start = microtime(true) ;

for($i = 0; $i<10000; $i++) {
    $redis->get(&#39;key&#39;);
}
echo microtime(true) - $start;     //执行5次,大概平均结果为 2.1236310005188 秒
Effectuer 10 000 tests de lecture sur la mémoire partagée (shm)

<?php
$key = 0x4337b123;  
$size = 1024;  
$shmid = @shmop_open($key, &#39;c&#39;, 0644, $size);  
$start = microtime(true);
for($i = 0; $i<10000; $i++) {
    shmop_read($shmid, 0,1024);
}
@shmop_close($shmid);
echo microtime(true) - $start;     //执行5次,大概平均结果为 0.0021078586578369 秒

Liste des résultats

Lecture Redis : 2,1 secondes Écriture : 1,7 secondes

Lecture Shm : 0,0021 secondes Écriture : 0,0025 secondes

On voit que l'effet est très différent.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

php implémente la fonction de communication du processus de mémoire partagée (_shm)

Détection automatique du code PHP (git/ svn intégré PHP_CodeSniffer)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn