gpt4 book ai didi

performance - 在 ycsb 的负载生成阶段之后,如何验证数据是否已加载到 mongodb 中?

转载 作者:可可西里 更新时间:2023-11-01 10:03:59 25 4
gpt4 key购买 nike

我正在尝试使用 ycsb 来执行 mongodb 的基准测试。

我已经按照 YCSB MongoDB 上指定的说明下载并安装了 mongo db

之后,我使用以下命令在 mongodb 中创建了名为“ycsb”的数据库

1. use ycsb 
2. db.createCollection("ycsb")

如上链接所述,我运行了以下命令将数据加载到 ycsb 数据库中,

./bin/ycsb load mongodb -s -P workloads/workloada -p mongodb.url=mongodb://127.0.0.1:27017 -p mongodb.database=ycsb

我只是想检查加载阶段的执行情况,所以我没有指定其他参数。我在登录屏幕下方,

root@pegdb2:~/ycsb-0.1.4# ./bin/ycsb load mongodb -s -P workloads/workloada -p mongodb.url=mongodb://127.0.0.1:27017 -p mongodb.database=ycsb
java -cp /root/ycsb-0.1.4/gemfire-binding/conf:/root/ycsb-0.1.4/infinispan-binding/conf:/root/ycsb-0.1.4/nosqldb-binding/conf:/root/ycsb-0.1.4/core/lib/core-0.1.4.jar:/root/ycsb-0.1.4/hbase-binding/conf:/root/ycsb-0.1.4/mongodb-binding/lib/mongodb-binding-0.1.4.jar:/root/ycsb-0.1.4/voldemort-binding/conf:/root/ycsb-0.1.4/jdbc-binding/conf com.yahoo.ycsb.Client -db com.yahoo.ycsb.db.MongoDbClient -s -P workloads/workloada -p mongodb.url=mongodb://127.0.0.1:27017 -p mongodb.database=ycsb -load
YCSB Client 0.1
Command line: -db com.yahoo.ycsb.db.MongoDbClient -s -P workloads/workloada -p mongodb.url=mongodb://127.0.0.1:27017 -p mongodb.database=ycsb -load
Loading workload...
Starting test.
new database url = 127.0.0.1:27017/ycsb
0 sec: 0 operations;
mongo connection created with 127.0.0.1:27017/ycsb
java.lang.NullPointerException
0 sec: 0 operations; [INSERT AverageLatency(us)=28568]
[OVERALL], RunTime(ms), 143.0
[OVERALL], Throughput(ops/sec), 0.0
[INSERT], Operations, 1
[INSERT], AverageLatency(us), 28568.0
[INSERT], MinLatency(us), 28568
[INSERT], MaxLatency(us), 28568
[INSERT], 95thPercentileLatency(ms), 28
[INSERT], 99thPercentileLatency(ms), 28
[INSERT], Return=1, 1
[INSERT], 0, 0
[INSERT], 1, 0
[INSERT], 2, 0
[INSERT], 3, 0
[INSERT], 4, 0
[INSERT], 5, 0
[INSERT], 6, 0
[INSERT], 7, 0
[INSERT], 8, 0
[INSERT], 9, 0
[INSERT], 10, 0
.
.
[INSERT], 999, 0
[INSERT], >1000, 0

在这一步之后,我只想检查是否在数据库中加载成功。我检查过使用,

1. use ycsb
2. db.ycsb.find()

但搜索结果为 0。这可能是一个非常简单的问题,但如果有人为我提供正确的方法来加载和验证数据库中的数据,将会很有帮助。

感谢您的帮助。

最佳答案

问题出在我在加载数据时没有指定的一个必需参数。

mongodb.writeConcern 是加载数据和运行工作负载时所需的参数。它应该具有以下值之一,

-p mongodb.writeConcern=none
-p mongodb.writeConcern=strict
-p mongodb.writeConcern=normal

通常 -p mongodb.writeConcern=strict 可以保持 session 打开和一致。这也会停止出现 NPE 错误。

在 MongoDB 中加载数据后,可以使用 db.usertable.find()db.usertable.count 在 usertable 表/集合中验证数据() 命令。

关于performance - 在 ycsb 的负载生成阶段之后,如何验证数据是否已加载到 mongodb 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27654413/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com