All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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