使用PHP驅動的MongoDB的單點查詢效能測試
之前的測試,發現MongoDB的插入操作在使用PHP驅動時比使用mongo控制檯更快。測試發現查詢也是類似的情況(以下測試都使用WT引擎)。
http://blog.chinaunix.net/uid-20726500-id-4998173.html
1. 插入資料
點選(此處)摺疊或開啟
-
–bash–4.1$ cat test.php
-
?php
- header(“Content-Type:text/html;charset=utf-8”);
- //MongoDB有使用者名稱密碼並指定資料庫admin
- $conn = new Mongo(“mongodb://127.0.0.1:27017/benchmark”);
- $db = $conn–>admin;
- //定製結果集(表名things)
- $collection = $db–>members;
- //$time1 = xdebug_time_index();
-
for($i=1;$i1000000;$i++){
- $user = array(`uname` => `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
-
?php
- header(“Content-Type:text/html;charset=utf-8”);
- $conn = new Mongo(“mongodb://127.0.0.1:27017/benchmark”);
- $db = $conn–>admin;
- $collection = $db–>members;
-
for($i=1;$i1000000;$i++){
- $query = array( `uname` => `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的結果
點選(此處)摺疊或開啟
- [root@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
-
?php
- header(“Content-Type:text/html;charset=utf-8”);
- //MongoDB有使用者名稱密碼並指定資料庫admin
- $conn = new Mongo(“mongodb://127.0.0.1:27017/benchmark”);
- $db = $conn–>admin;
- //定製結果集(表名things)
- $collection = $db–>members;
- //$time1 = xdebug_time_index();
-
for($i=1;$i1000000;$i++){
- $user = array(`_id` => `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
-
?php
- header(“Content-Type:text/html;charset=utf-8”);
- $conn = new Mongo(“mongodb://127.0.0.1:27017/benchmark”);
- $db = $conn–>admin;
- $collection = $db–>members;
-
for($i=1;$i1000000;$i++){
- $query = array( `_id` => `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結果
點選(此處)摺疊或開啟
- [root@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。
相關文章
- 測試驅動開發(TDD)—— 資料庫查詢篇資料庫
- MongoDB分頁查詢的方法及效能MongoDB
- MongoDB 分頁查詢的方法及效能MongoDB
- TDD---測試驅動開發,簡單的一點認識
- kdb+/q的列表排序和查詢效能測試排序
- PHP單元測試框架PHPUnit的使用PHP框架
- 移動效能測試---工具PerfDog簡單使用
- DDT資料驅動效能測試(一)
- Laravel使用MongoDB複雜的查詢LaravelMongoDB
- Laravel 測試驅動開發 -- 正向單元測試Laravel
- MySQL連線查詢驅動表被驅動表以及效能優化MySql優化
- 【PG效能測試】pgbench效能測試工具簡單使用
- es的複雜查詢測試,使用jest的dsl工具寫查詢語句
- Jmeter效能測試簡單使用JMeter
- TestComplete使用關鍵字測試的資料驅動測試(三)
- 功能測試-登陸、新增、刪除、查詢測試要點
- try的簡單效能測試
- 介面測試裡的查詢介面要測試嗎
- SpringBoot 框架MongoDB 簡單的查詢方式Spring Boot框架MongoDB
- 談“測試驅動的開發”
- 使用strace來查詢php的坑PHP
- 3 個主流 PHP 框架的效能測試PHP框架
- Mongodb 常用的查詢方法MongoDB
- mongoDB的主從複製簡單測試MongoDB
- 功能測試、自動化測試、效能測試的區別
- php8.0 及php7.2效能基準簡單測試PHP
- 使用Google抓取方式,測試React驅動的網站SEOGoReact網站
- 測試開發之單元測試-禪道結合ZTF驅動單元測試執行
- 測試驅動開發(TDD)的思考
- 使用 sysbench 測試 MySQL 的效能MySql
- mongodb查詢MongoDB
- MongoDB Python官方驅動 PyMongo 的簡單封裝MongoDBPython封裝
- PHP 單元測試PHP
- MongoDB的排除查詢$ne缺陷MongoDB
- MONGODB 最近測試結果的簡單記錄MongoDB
- TDengine 和 InfluxDB 查詢效能對比測試報告UX測試報告
- 【效能測試】使用ab做Http效能測試HTTP
- golang 表格驅動測試Golang