我通过比较 Tokumx 和纯 Mongodb 来进行读取性能压力测试。
- Tokumx 社区版 2.0.0
- MongoDB 2.6.4_1
tokumx 和 mongodb 都在同一台机器上运行。
硬件概述:
Model Name: Mac mini
Model Identifier: Macmini6,1
Processor Name: Intel Core i5
Processor Speed: 2.5 GHz
Number of Processors: 1
Total Number of Cores: 2
L2 Cache (per Core): 256 KB
L3 Cache: 3 MB
Memory: 10 GB
每个实例中只有一个集合。每个集合中有 100,000 个条目。
对于 tokumx,它被创建为分区集合。但是对于 mongodb,它是作为普通集合创建的:
db.createCollection("sample", {partitioned: true, primaryKey: {field1:1, _id: 1}});
对于这两种情况,索引如下所示:
db.sample.ensureIndex({field1:1});
db.sample.ensureIndex({field2:1});
db.sample.ensureIndex({field3:1});
db.sample.ensureIndex({field4:1});
db.sample.ensureIndex({geo:"2d"});
db.sample.ensureIndex({"created_at":1});
我正在使用Tsung进行压力测试。在测试计划中,我通过查找field2
和按desc的geo
字段顺序进行了简单的搜索。created_at
<clients>
<client host="localhost" use_controller_vm="false" maxusers="8000"/>
</clients>
<servers>
<server host="jchimac.thenetcircle.lab" port="8080" type="tcp"/>
</servers>
<load duration="5" unit="minute">
<arrivalphase phase="1" duration="5" unit="minute">
<users interarrival="0.03" unit="second"/>
</arrivalphase>
</load>
根据官方文件,交易应该类似于TOKUMX™ BENCHMARK VS。MONGODB – 硬盘
但在我的测试中:
托库克斯:
MongoDB:
我在这里问知道是否有人可以对此提供任何提示?我在整个测试中错过了什么吗?
更新:
我在 Linux(CentOS) 机器上又做了一轮测试:
CentOS release 6.5 (Final)
2.6.32-504.1.3.el6.x86_64 GNU/Linux
MemTotal: 24589896 kB
CPU: 12* (Intel(R) Xeon(R) CPU E5645 @ 2.40GHz)
示例数据如下所示:
{
"_id": ObjectId("54867dc8ffbc15aa2bc3ee0e"),
"_iid": 15,
"_pid": 15,
"uid": 102296,
"nickname": "nickname_102296",
"gender": 3,
"image_id": 15,
"created_at": 1418100168,
"tag": 1,
"geo": {
"lat": 51.590449999999997033,
"lon": 6.9671900000000004383
}
}
每个集合有 1,000,000 个条目。
每个集合的索引(创建正常集合):
db.createCollection("coll", {primaryKey: {_pid:1, _id: 1}});
db.tokumx_coll.ensureIndex({gender:1});
db.tokumx_coll.ensureIndex({uid:1});
db.tokumx_coll.ensureIndex({geo:"2d"});
db.tokumx_coll.ensureIndex({_pid:1});
db.tokumx_coll.ensureIndex({_iid:1});
db.tokumx_coll.ensureIndex({"created_at":1});
测试计划也很简单:
{'$query', {gender,3,geo, {'$geoWithin', {'$center', [[48.72761, 9.24596], 0.005]}}}, '$orderby',{'_pid',-1}}
每次测试运行 1 小时的 Tsung 压力测试。并发是每秒 1 个请求。
<load>
<arrivalphase phase="1" duration="60" unit="minute">
<users interarrival="1" unit="second"/>
</arrivalphase>
</load>
这是屏幕截图中的报告:
托库克斯:
蒙古数据库:
更新@2014.12.12 发现这个: https ://github.com/Tokutek/mongo/issues/1014