RecordIteratorBenchmark.java
/*******************************************************************************
* Copyright (c) 2025 Eclipse RDF4J contributors.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*******************************************************************************/
package org.eclipse.rdf4j.sail.lmdb;
import java.io.File;
import java.io.IOException;
import java.util.concurrent.TimeUnit;
import org.apache.commons.io.FileUtils;
import org.assertj.core.util.Files;
import org.eclipse.rdf4j.sail.lmdb.config.LmdbStoreConfig;
import org.openjdk.jmh.annotations.*;
import org.openjdk.jmh.infra.Blackhole;
/**
* @author Piotr Sowi��ski
*/
@State(Scope.Benchmark)
@Warmup(iterations = 5)
@BenchmarkMode({ Mode.AverageTime })
@Fork(value = 4, jvmArgs = { "-Xms1G", "-Xmx1G" })
//@Fork(value = 1, jvmArgs = {"-Xms1G", "-Xmx1G", "-XX:StartFlightRecording=jdk.CPUTimeSample#enabled=true,filename=profile.jfr,method-profiling=max","-XX:FlightRecorderOptions=stackdepth=1024", "-XX:+UnlockDiagnosticVMOptions", "-XX:+DebugNonSafepoints"})
@Threads(value = 8)
@Measurement(iterations = 10)
@OutputTimeUnit(TimeUnit.MILLISECONDS)
public class RecordIteratorBenchmark {
private File dataDir;
private TripleStore tripleStore;
@Setup(Level.Trial)
public void setup() throws IOException {
dataDir = Files.newTemporaryFolder();
tripleStore = new TripleStore(dataDir, new LmdbStoreConfig("spoc,posc"));
final int statements = 1_000_000;
tripleStore.startTransaction();
for (int i = 0; i < statements; i++) {
tripleStore.storeTriple(i, i + 1, i + 2, 1, true);
}
tripleStore.commit();
}
@TearDown(Level.Trial)
public void tearDown() throws IOException {
tripleStore.close();
FileUtils.deleteDirectory(dataDir);
}
@Benchmark
public void iterateAll(Blackhole blackhole) throws IOException {
try (TxnManager.Txn txn = tripleStore.getTxnManager().createReadTxn()) {
try (RecordIterator it = tripleStore.getTriples(txn, 0, 0, 0, 1, true)) {
long[] item;
while ((item = it.next()) != null) {
blackhole.consume(item);
}
}
}
}
}