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

com.clickhouse.benchmark.misc.QueueBenchmark Maven / Gradle / Ivy

package com.clickhouse.benchmark.misc;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
import org.openjdk.jmh.annotations.Benchmark;
import org.openjdk.jmh.annotations.BenchmarkMode;
import org.openjdk.jmh.annotations.Fork;
import org.openjdk.jmh.annotations.Level;
import org.openjdk.jmh.annotations.Measurement;
import org.openjdk.jmh.annotations.Mode;
import org.openjdk.jmh.annotations.OutputTimeUnit;
import org.openjdk.jmh.annotations.Scope;
import org.openjdk.jmh.annotations.Setup;
import org.openjdk.jmh.annotations.State;
import org.openjdk.jmh.annotations.Threads;
import org.openjdk.jmh.annotations.Warmup;
import org.openjdk.jmh.infra.Blackhole;
import com.clickhouse.benchmark.BaseState;
import com.clickhouse.client.ClickHouseClient;
import com.clickhouse.client.ClickHouseConfig;
import com.clickhouse.client.config.ClickHouseClientOption;
import com.clickhouse.config.ClickHouseBufferingMode;
import com.clickhouse.config.ClickHouseOption;
import com.clickhouse.data.ClickHouseByteBuffer;
import com.clickhouse.data.ClickHouseDataStreamFactory;
import com.clickhouse.data.ClickHouseInputStream;
import com.clickhouse.data.ClickHouseOutputStream;
import com.clickhouse.data.ClickHousePipedOutputStream;
import com.clickhouse.data.format.BinaryStreamUtils;

@State(Scope.Benchmark)
@Warmup(iterations = 10, timeUnit = TimeUnit.SECONDS, time = 1)
@Measurement(iterations = 10, timeUnit = TimeUnit.SECONDS, time = 1)
@Fork(value = 2)
@Threads(value = -1)
@BenchmarkMode(Mode.Throughput)
@OutputTimeUnit(TimeUnit.SECONDS)
public class QueueBenchmark {
    @State(Scope.Thread)
    public static class CompareState extends BaseState {
        public long samples;

        @Setup(Level.Trial)
        public void setupSamples() {
            samples = 5000000L;
        }

        @Setup(Level.Iteration)
        public void initValueClass() {
            // ignore
        }
    }

    @Benchmark
    public void ideal(CompareState state, Blackhole consumer) {
        long range = state.samples;
        byte[] bytes = new byte[8];
        ClickHouseByteBuffer buffer = ClickHouseByteBuffer.of(bytes);
        for (long i = 0L; i < range; i++) {
            BinaryStreamUtils.setInt64(bytes, 0, i);
            consumer.consume(buffer.asLong());
            buffer.update(bytes); // reset read position
        }
    }

    @Benchmark
    public void blocking(CompareState state, Blackhole consumer) throws Exception {
        Map options = new HashMap<>();
        // options.put(ClickHouseClientOption.BUFFER_QUEUE_VARIATION, 0);
        // options.put(ClickHouseClientOption.MAX_QUEUED_BUFFERS, 0);
        // options.put(ClickHouseClientOption.SOCKET_TIMEOUT, 0);
        options.put(ClickHouseClientOption.USE_BLOCKING_QUEUE, false);
        final ClickHouseConfig config = new ClickHouseConfig(options);
        final ClickHousePipedOutputStream stream = ClickHouseDataStreamFactory.getInstance()
                .createPipedOutputStream(config);
        CompletableFuture future = ClickHouseClient.submit(() -> {
            long range = state.samples;
            try (ClickHouseOutputStream out = stream) {
                for (long i = 0L; i < range; i++) {
                    BinaryStreamUtils.writeInt64(out, i);
                }
            }
            return range;
        });

        try (ClickHouseInputStream input = stream.getInputStream()) {
            consumer.consume(BinaryStreamUtils.readInt64(input));
        }

        consumer.consume(future.get());
    }

    @Benchmark
    public void nonBlocking(CompareState state, Blackhole consumer) throws Exception {
        final ClickHouseConfig config = new ClickHouseConfig(Collections
                .singletonMap(ClickHouseClientOption.RESPONSE_BUFFERING, ClickHouseBufferingMode.PERFORMANCE));
        final ClickHousePipedOutputStream stream = ClickHouseDataStreamFactory.getInstance()
                .createPipedOutputStream(config);
        CompletableFuture future = ClickHouseClient.submit(() -> {
            long range = state.samples;
            try (ClickHouseOutputStream out = stream) {
                for (long i = 0L; i < range; i++) {
                    BinaryStreamUtils.writeInt64(out, i);
                }
            }
            return range;
        });

        try (ClickHouseInputStream input = stream.getInputStream()) {
            consumer.consume(BinaryStreamUtils.readInt64(input));
        }

        consumer.consume(future.get());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy