设为首页 收藏本站
查看: 1378|回复: 0

[经验分享] 使用PHP驱动的MongoDB的单点查询性能测试

[复制链接]
发表于 2015-12-22 14:23:54 | 显示全部楼层 |阅读模式
之前的测试,发现MongoDB的插入操作在使用PHP驱动时比使用mongo控制台更快。测试发现查询也是类似的情况(以下测试都使用WT引擎)。
http://blog.iyunv.com/uid-20726500-id-4998173.html

1. 插入数据



  • -bash-4.1$ cat test.php

  • admin;
  • //定制结果集(表名things)
  • $collection = $db->members;
  • //$time1 = xdebug_time_index();

  • for($i=1;$i 'chuchuchu_'.$i, 'name' => '褚褚褚', 'password' => 'e10adc3949ba59abbe56e057f20f883e', 'email' => 'dhaig@yahoo.com.cn');
  • $collection->insert($user);
  • }

  • $conn->close();
  • //$time2 = xdebug_time_index();
  • //echo "MongoDB响应时间为:".($time2-$time1)."秒";
  • ?>

  • -bash-4.1$ time php test.php


  • real    1m45.062s
  • user    0m22.609s
  • sys    0m12.569s

2. 建索引



  • -bash-4.1$ mongo benchmark

  • ...
  • > use admin
  • switched to db admin
  • > db.members.ensureIndex({uname:1})
  • {
  •     "createdCollectionAutomatically" : false,
  •     "numIndexesBefore" : 1,
  •     "numIndexesAfter" : 2,
  •     "ok" : 1
  • }

3.单点索引查询



  • -bash-4.1$ cat test_sel.php

  • admin;
  • $collection = $db->members;

  • for($i=1;$i 'chuchuchu_'.$i);
  • $cursor = $collection->find( $query );
  • while( $cursor->hasNext() ) {
  •     $var=$cursor->getNext();
  • }
  • }

  • $conn->close();

  • ?>

  • -bash-4.1$ time php test_sel.php

  • real    1m42.998s
  • user    0m22.888s
  • sys    0m13.160s

top的结果



  • [iyunv@hanode1 ~]# top
  • top - 03:27:45 up 8 days, 8:04, 6 users, load average: 0.35, 0.35, 0.17
  • Tasks: 152 total, 1 running, 151 sleeping, 0 stopped, 0 zombie
  • Cpu(s): 18.7%us, 5.2%sy, 0.0%ni, 74.2%id, 0.0%wa, 0.0%hi, 2.0%si, 0.0%st
  • Mem: 1019320k total, 952192k used, 67128k free, 155224k buffers
  • Swap: 2064376k total, 184k used, 2064192k free, 332756k cached

  • PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
  • 24809 postgres 20 0 575m 294m 11m S 65.2 29.6 3:23.02 mongod
  • 28124 postgres 20 0 208m 7016 4528 S 34.9 0.7 0:02.05 php

索引查询速度大约每秒1w次,mongod消耗CPU 65.2%,经过计算将1个cpu core用满可以达到1.5w/s(1/0.652)。

4. 一级索引的测试
上面是二级索引的测试,那么"_id"的一级索引,性能会不会还有提升空间呢?也测一下看看。

4.1 先把之前是数据删掉。



  • -bash-4.1$ mongo benchmark
  • ...
  • > use admin
  • switched to db admin
  • > db.members.drop()
  • true

4.2 插入数据



  • -bash-4.1$ cat test_2.php

  • admin;
  • //定制结果集(表名things)
  • $collection = $db->members;
  • //$time1 = xdebug_time_index();

  • for($i=1;$i 'chuchuchu_'.$i, 'name' => '褚褚褚', 'password' => 'e10adc3949ba59abbe56e057f20f883e', 'email' => 'dhaig@yahoo.com.cn');
  • $collection->insert($user);
  • }

  • $conn->close();
  • //$time2 = xdebug_time_index();
  • //echo "MongoDB响应时间为:".($time2-$time1)."秒";
  • ?>

  • -bash-4.1$ time php test_2.php


  • real    1m43.274s
  • user    0m21.286s
  • sys    0m12.985s
原来test.php中的'uname'被改成了'_id'


4.3 查询数据
点击(此处)折叠或打开


  • -bash-4.1$ cat test_sel_2.php

  • admin;
  • $collection = $db->members;

  • for($i=1;$i 'chuchuchu_'.$i);
  • $cursor = $collection->find( $query );
  • while( $cursor->hasNext() ) {
  •     $var=$cursor->getNext();
  • }
  • }

  • $conn->close();

  • ?>

  • -bash-4.1$ time php test_sel_2.php

  • real    1m19.557s
  • user    0m21.236s
  • sys    0m12.156s
原来test_sel.php中的'uname'被改成了'_id'

查询top结果




  • [iyunv@hanode1 ~]# top
  • top - 03:40:51 up 8 days, 8:17, 6 users, load average: 0.21, 0.37, 0.28
  • Tasks: 152 total, 2 running, 150 sleeping, 0 stopped, 0 zombie
  • Cpu(s): 17.5%us, 5.5%sy, 0.0%ni, 74.9%id, 0.0%wa, 0.0%hi, 2.1%si, 0.0%st
  • Mem: 1019320k total, 787364k used, 231956k free, 83380k buffers
  • Swap: 2064376k total, 184k used, 2064192k free, 142384k cached

  • PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
  • 24809 postgres 20 0 711m 420m 11m R 58.2 42.2 6:02.83 mongod
  • 29480 postgres 20 0 208m 7016 4528 S 41.6 0.7 0:02.78 php

索引查询速度大约每秒1.26w次,mongod消耗CPU 58.2% ,经过计算将1个cpu core用满可以达到2.2w/s(1/0.582)。

5. 总结
在我的测试环境下,假设mongod 用满1个CPU core,一级索引的单点查询QPS可达到2.2w/s,二级索引则大约是1.5w/s。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-154854-1-1.html 上篇帖子: 用户名、密码 连接mongodb数据库 下篇帖子: MongoDB数据同步工具mongosync
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表