gpt4 book ai didi

java - YCSB 对 mysql 数据库进行扫描操作时出错

转载 作者:行者123 更新时间:2023-11-29 23:26:12 25 4
gpt4 key购买 nike

我正在尝试使用 YCSB 客户端在 MySQL 数据库(10GB 设置)上运行仅扫描工作负载。我正在使用以下命令来运行工作负载

./bin/ycsb 运行 jdbc -P 工作负载/workloademod -p db.driver=com.mysql.jd bc.Driver -p db.url=jdbc:mysql://localhost:3306/ycsbtest -p db. user=用户名 -p maxscanlength=100 -p recordcount=5000 -p operationcount=1000 -p maxexecutiontime=1800 > try_ycsb_emod

但是我遇到了 java GC 内存不足异常,并且工作负载被终止,如下所示:-

Loading workload...
Starting test.
Maximum execution time specified as: 1800 secs
Exception in thread "Thread-1" java.lang.OutOfMemoryError: Java heap space
at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3380)
at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3327)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3814)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:870)
at com.mysql.jdbc.MysqlIO.nextRow(MysqlIO.java:1928)
at com.mysql.jdbc.MysqlIO.readSingleRowSet(MysqlIO.java:3278)
at com.mysql.jdbc.MysqlIO.getResultSet(MysqlIO.java:462)
at com.mysql.jdbc.MysqlIO.readResultsForQueryOrUpdate(MysqlIO.java:2997)
at com.mysql.jdbc.MysqlIO.readAllResults(MysqlIO.java:2245)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2638)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2530)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1907)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2030)
at com.yahoo.ycsb.db.JdbcDBClient.scan(JdbcDBClient.java:348)
at com.yahoo.ycsb.DBWrapper.scan(DBWrapper.java:107)
at com.yahoo.ycsb.workloads.CoreWorkload.doTransactionScan(CoreWorkload.java:605)
at com.yahoo.ycsb.workloads.CoreWorkload.doTransaction(CoreWorkload.java:491)
at com.yahoo.ycsb.ClientThread.run(Client.java:233)
Could not wait until max specified time, TerminatorThread interrupted.

我尝试通过执行“export YCSB_HEAP_SIZE=8000”来增加 ycsb 客户端的 java 堆大小,使其达到 8G,但仍然遇到相同的错误。

我检查了 ycsb 客户端发送到 mysql 服务器的 mysql 查询,但没有看到对 max_scan_length 指标的引用/暗示。另外,使用 mysql 客户端而不是 ycsb 客户端运行此 mysql 查询效果很好。

我不知道我能做些什么来解决这个问题。有人可以帮我吗?

谢谢,雷内

最佳答案

这是 jdbc 实现的一个错误: https://github.com/brianfrankcooper/YCSB/issues/171

关于java - YCSB 对 mysql 数据库进行扫描操作时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26938671/

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