使用PHP驱动的MongoDB的单点查询性能测试

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
性能测试 PTS,5000VUM额度
简介: 之前的测试,发现MongoDB的插入操作在使用PHP驱动时比使用mongo控制台更快。测试发现查询也是类似的情况(以下测试都使用WT引擎)。http://blog.chinaunix.net/uid-20726500-id-4998173.
之前的测试,发现MongoDB的插入操作在使用PHP驱动时比使用mongo控制台更快。测试发现查询也是类似的情况 (以下测试都使用WT引擎)
http://blog.chinaunix.net/uid-20726500-id-4998173.html

1. 插入数据

点击(此处)折叠或打开

  1. -bash-4.1$ cat test.php
  2. ?php
  3. header("Content-Type:text/html;charset=utf-8");
  4. //MongoDB有用户名密码并指定数据库admin
  5. $conn = new Mongo("mongodb://127.0.0.1:27017/benchmark");
  6.   
  7. $db = $conn->admin;
  8. //定制结果集(表名things)
  9. $collection = $db->members;
  10. //$time1 = xdebug_time_index();

  11. for($i=1;$i1000000;$i++){
  12. $user = array('uname' => 'chuchuchu_'.$i, 'name' => '褚褚褚', 'password' => 'e10adc3949ba59abbe56e057f20f883e', 'email' => 'dhaig@yahoo.com.cn');
  13. $collection->insert($user);
  14. }

  15. $conn->close();
  16. //$time2 = xdebug_time_index();
  17. //echo "MongoDB响应时间为:".(time2time1)."秒";
  18. ?>

  19. -bash-4.1$ time php test.php
  20.  

  21. real    1m45.062s
  22. user    0m22.609s
  23. sys    0m12.569s

2. 建索引

点击(此处)折叠或打开

  1. -bash-4.1$ mongo benchmark
  2. ...
  3. > use admin
  4. switched to db admin
  5. > db.members.ensureIndex({uname:1})
  6. {
  7.     "createdCollectionAutomatically" : false,
  8.     "numIndexesBefore" : 1,
  9.     "numIndexesAfter" : 2,
  10.     "ok" : 1
  11. }

3.单点索引查询

点击(此处)折叠或打开

  1. -bash-4.1$ cat test_sel.php
  2. ?php
  3. header("Content-Type:text/html;charset=utf-8");
  4. $conn = new Mongo("mongodb://127.0.0.1:27017/benchmark");

  5. $db = $conn->admin;
  6. $collection = $db->members;

  7. for($i=1;$i1000000;$i++){
  8. $query = array( 'uname' => 'chuchuchu_'.$i);
  9. $cursor = $collection->find( $query );
  10. while( $cursor->hasNext() ) {
  11.     $var=$cursor->getNext();
  12. }
  13. }

  14. $conn->close();

  15. ?>

  16. -bash-4.1$ time php test_sel.php

  17. real    1m42.998s
  18. user    0m22.888s
  19. sys    0m13.160s

top的结果

点击(此处)折叠或打开

  1. [root@hanode1 ~]# top
  2. top - 03:27:45 up 8 days, 8:04, 6 users, load average: 0.35, 0.35, 0.17
  3. Tasks: 152 total, 1 running, 151 sleeping, 0 stopped, 0 zombie
  4. 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
  5. Mem: 1019320k total, 952192k used, 67128k free, 155224k buffers
  6. Swap: 2064376k total, 184k used, 2064192k free, 332756k cached
  7. PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
  8. 24809 postgres 20 0 575m 294m 11m S 65.2 29.6 3:23.02 mongod
  9. 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 先把之前是数据删掉。

点击(此处)折叠或打开

  1. -bash-4.1$ mongo benchmark
  2. ...
  3. > use admin
  4. switched to db admin
  5. > db.members.drop()
  6. true

4.2 插入数据

点击(此处)折叠或打开

  1. -bash-4.1$ cat test_2.php
  2. ?php
  3. header("Content-Type:text/html;charset=utf-8");
  4. //MongoDB有用户名密码并指定数据库admin
  5. $conn = new Mongo("mongodb://127.0.0.1:27017/benchmark");
  6.   
  7. $db = $conn->admin;
  8. //定制结果集(表名things)
  9. $collection = $db->members;
  10. //$time1 = xdebug_time_index();

  11. for($i=1;$i1000000;$i++){
  12. $user = array('_id' => 'chuchuchu_'.$i, 'name' => '褚褚褚', 'password' => 'e10adc3949ba59abbe56e057f20f883e', 'email' => 'dhaig@yahoo.com.cn');
  13. $collection->insert($user);
  14. }

  15. $conn->close();
  16. //$time2 = xdebug_time_index();
  17. //echo "MongoDB响应时间为:".(time2time1)."秒";
  18. ?>

  19. -bash-4.1$ time php test_2.php
  20.  

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


4.3 查询数据

点击( 此处 )折叠或打开
  1. -bash-4.1$ cat test_sel_2.php
  2. ?php
  3. header("Content-Type:text/html;charset=utf-8");
  4. $conn = new Mongo("mongodb://127.0.0.1:27017/benchmark");

  5. $db = $conn->admin;
  6. $collection = $db->members;

  7. for($i=1;$i1000000;$i++){
  8. $query = array( '_id' => 'chuchuchu_'.$i);
  9. $cursor = $collection->find( $query );
  10. while( $cursor->hasNext() ) {
  11.     $var=$cursor->getNext();
  12. }
  13. }

  14. $conn->close();

  15. ?>

  16. -bash-4.1$ time php test_sel_2.php

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

查询top结果

点击(此处)折叠或打开

  1. [root@hanode1 ~]# top
  2. top - 03:40:51 up 8 days, 8:17, 6 users, load average: 0.21, 0.37, 0.28
  3. Tasks: 152 total, 2 running, 150 sleeping, 0 stopped, 0 zombie
  4. 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
  5. Mem: 1019320k total, 787364k used, 231956k free, 83380k buffers
  6. Swap: 2064376k total, 184k used, 2064192k free, 142384k cached
  7. PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
  8. 24809 postgres 20 0 711m 420m 11m R 58.2 42.2 6:02.83 mongod
  9. 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。



相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
打赏
0
0
0
0
50
分享
相关文章
PHP成绩查询系统源码
PHP成绩查询系统源码
569 3
掌握MongoDB索引优化策略:提升查询效率的关键
在数据库性能调优中,索引是提升查询效率的利器。本文将带你深入了解MongoDB索引的内部工作原理,探讨索引对查询性能的影响,并通过实际案例指导如何针对不同的查询模式建立有效的索引。不仅将涵盖单一字段索引,还会探讨复合索引的使用,以及如何通过分析查询模式和执行计划来优化索引,最终实现查询性能的最大化。
使用PHP接入纯真IP库:实现IP地址地理位置查询
本文介绍了如何使用PHP接入纯真IP库(QQWry),实现IP地址的地理位置查询。纯真IP库是一个轻量级的IP数据库,数据格式简单,查询速度快,适合Web应用。首先,下载并放置`QQWry.dat`文件到项目目录。接着,通过编写PHP类解析该文件,实现IP查询功能。最后,提供了一个完整的案例演示,展示如何查询IP地址对应的国家和地区信息。该工具适用于用户地理位置分析、访问日志分析和风控系统等场景,具有轻量级、查询速度快、数据更新方便等优点。
|
2月前
|
Java使用sql查询mongodb
通过MongoDB Atlas Data Lake或Apache Drill,可以在Java中使用SQL语法查询MongoDB数据。这两种方法都需要适当的配置和依赖库的支持。希望本文提供的示例和说明能够帮助开发者实现这一目标。
63 17
【YashanDB 知识库】php 查询超过 256 长度字符串,数据被截断的问题
php 查询超过 256 字节数据,显示被截断:yashandb 的 odbc 驱动接口 SQLGetData 现在只支持单次查询,不支持多次取数据的操作。 isql 显示不出来,isql 工具最大只查询 300 长度的数据,超过了该长度未正常显示。
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
827 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
3月前
|
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
140 9
智能化软件测试:AI驱动的自动化测试策略与实践####
本文深入探讨了人工智能(AI)在软件测试领域的创新应用,通过分析AI技术如何优化测试流程、提升测试效率及质量,阐述了智能化软件测试的核心价值。文章首先概述了传统软件测试面临的挑战,随后详细介绍了AI驱动的自动化测试工具与框架,包括自然语言处理(NLP)、机器学习(ML)算法在缺陷预测、测试用例生成及自动化回归测试中的应用实例。最后,文章展望了智能化软件测试的未来发展趋势,强调了持续学习与适应能力对于保持测试策略有效性的重要性。 ####
|
5月前
|
MongoDB PHP
10月更文挑战第19天
54 2
MongoDB PHP
|
4月前
|
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
134 4

热门文章

最新文章