
com.palantir.atlasdb.timelock.benchmarks.BenchmarksResource Maven / Gradle / Ivy
/*
* (c) Copyright 2018 Palantir Technologies Inc. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.palantir.atlasdb.timelock.benchmarks;
import com.codahale.metrics.MetricRegistry;
import com.palantir.atlasdb.config.AtlasDbConfig;
import com.palantir.atlasdb.factory.TransactionManagers;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.KvsPutUnlessExistsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.KvsReadBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.KvsWriteBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.LockAndUnlockContendedBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.LockAndUnlockUncontendedBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.RangeScanDynamicColumnsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.RangeScanRowsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.TimestampBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.TransactionReadRowsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.TransactionWriteBenchmarkContended;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.TransactionWriteDynamicColumnsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.benchmarks.TransactionWriteRowsBenchmark;
import com.palantir.atlasdb.timelock.benchmarks.schema.BenchmarksSchema;
import com.palantir.atlasdb.transaction.api.TransactionManager;
import com.palantir.conjure.java.api.config.service.UserAgent;
import com.palantir.tritium.metrics.registry.SharedTaggedMetricRegistries;
import java.util.Map;
import java.util.Optional;
public class BenchmarksResource implements BenchmarksService {
private final TransactionManager txnManager;
public BenchmarksResource(AtlasDbConfig config) {
this.txnManager = TransactionManagers.builder()
.config(config)
.userAgent(UserAgent.of(UserAgent.Agent.of("benchmarks", "0.0.0")))
.globalMetricsRegistry(new MetricRegistry())
.globalTaggedMetricRegistry(SharedTaggedMetricRegistries.getSingleton())
.addSchemas(BenchmarksSchema.SCHEMA)
.allowHiddenTableAccess(true)
.runtimeConfigSupplier(Optional::empty)
.build()
.serializable();
}
@Override
public Map transactionWriteRows(
int numClients, int numRequestsPerClient, int numRows, int dataSize) {
return TransactionWriteRowsBenchmark.execute(txnManager, numClients, numRequestsPerClient, numRows, dataSize);
}
@Override
public Map transactionWriteDynamicColumns(
int numClients, int numRequestsPerClient, int numRows, int dataSize) {
return TransactionWriteDynamicColumnsBenchmark.execute(
txnManager, numClients, numRequestsPerClient, numRows, dataSize);
}
@Override
public Map transactionWriteContended(int numClients, int numRequestsPerClient) {
return TransactionWriteBenchmarkContended.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map lockAndUnlockUncontended(int numClients, int numRequestsPerClient) {
return LockAndUnlockUncontendedBenchmark.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map lockAndUnlockContended(int numClients, int numRequestsPerClient, int numDistinctLocks) {
return LockAndUnlockContendedBenchmark.execute(txnManager, numClients, numRequestsPerClient, numDistinctLocks);
}
@Override
public Map transactionReadRows(
int numClients, int numRequestsPerClient, int numRows, int dataSize) {
return TransactionReadRowsBenchmark.execute(txnManager, numClients, numRequestsPerClient, numRows, dataSize);
}
@Override
public Map kvsWrite(int numClients, int numRequestsPerClient) {
return KvsWriteBenchmark.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map kvsPutUnlessExists(int numClients, int numRequestsPerClient) {
return KvsPutUnlessExistsBenchmark.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map kvsRead(int numClients, int numRequestsPerClient) {
return KvsReadBenchmark.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map timestamp(int numClients, int numRequestsPerClient) {
return TimestampBenchmark.execute(txnManager, numClients, numRequestsPerClient);
}
@Override
public Map rangeScanRows(int numClients, int numRequestsPerClient, int dataSize, int numRows) {
return RangeScanRowsBenchmark.execute(txnManager, numClients, numRequestsPerClient, dataSize, numRows);
}
@Override
public Map rangeScanDynamicColumns(
int numClients, int numRequestsPerClient, int dataSize, int numRows) {
return RangeScanDynamicColumnsBenchmark.execute(
txnManager, numClients, numRequestsPerClient, dataSize, numRows);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy