com.rabbitmq.perf.BaseMetrics Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of perf-test Show documentation
Show all versions of perf-test Show documentation
A Java-based performance testing tool for RabbitMQ.
The newest version!
// Copyright (c) 2018-2023 Broadcom. All Rights Reserved.
// The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// This software, the RabbitMQ Java client library, is triple-licensed under the
// Mozilla Public License 2.0 ("MPL"), the GNU General Public License version 2
// ("GPL") and the Apache License version 2 ("ASL"). For the MPL, please see
// LICENSE-MPL-RabbitMQ. For the GPL, please see LICENSE-GPL2. For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].
package com.rabbitmq.perf;
import static com.rabbitmq.perf.Utils.strArg;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.impl.MicrometerMetricsCollector;
import io.micrometer.core.instrument.Tag;
import io.micrometer.core.instrument.Tags;
import io.micrometer.core.instrument.binder.jvm.ClassLoaderMetrics;
import io.micrometer.core.instrument.binder.jvm.JvmGcMetrics;
import io.micrometer.core.instrument.binder.jvm.JvmMemoryMetrics;
import io.micrometer.core.instrument.binder.jvm.JvmThreadMetrics;
import io.micrometer.core.instrument.binder.system.ProcessorMetrics;
import io.micrometer.core.instrument.composite.CompositeMeterRegistry;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
import org.apache.commons.cli.Option;
import org.apache.commons.cli.Options;
/** */
public class BaseMetrics implements Metrics {
private final AtomicInteger argumentsGauge = new AtomicInteger(1);
@Override
public Options options() {
Options options = new Options();
options.addOption(
new Option(
"mt", "metrics-tags", true, "metrics tags as key-value pairs separated by commas"));
options.addOption(
new Option(
"mcla",
"metrics-command-line-arguments",
false,
"add fixed metrics with command line arguments label"));
options.addOption(
new Option(
"mpx", "metrics-prefix", true, "prefix for PerfTest metrics, default is perftest_"));
options.addOption(new Option("mc", "metrics-client", false, "enable client metrics"));
options.addOption(
new Option("mcl", "metrics-class-loader", false, "enable JVM class loader metrics"));
options.addOption(new Option("mjm", "metrics-jvm-memory", false, "enable JVM memory metrics"));
options.addOption(new Option("mjgc", "metrics-jvm-gc", false, "enable JVM GC metrics"));
options.addOption(
new Option(
"mjp", "metrics-processor", false, "enable processor metrics (gathered by JVM)"));
options.addOption(new Option("mjt", "metrics-jvm-thread", false, "enable JVM thread metrics"));
return options;
}
@Override
public void configure(ConfigurationContext context) {
CommandLineProxy cmd = context.cmd();
CompositeMeterRegistry meterRegistry = context.meterRegistry();
ConnectionFactory factory = context.factory();
String argumentTags = strArg(cmd, "mt", null);
meterRegistry.config().commonTags(parseTags(argumentTags));
if (cmd.hasOption("mcla")) {
String metricsPrefix = context.metricsPrefix() == null ? "" : context.metricsPrefix();
String[] args = context.args();
Tags tags;
if (args == null || args.length == 0) {
tags = Tags.of("command_line", "");
} else {
tags = Tags.of("command_line", commandLineMetrics(args, context.metricsOptions()));
}
meterRegistry.gauge(metricsPrefix + "args", tags, argumentsGauge);
}
if (cmd.hasOption("mc")) {
factory.setMetricsCollector(new MicrometerMetricsCollector(meterRegistry, "client"));
}
if (cmd.hasOption("mcl")) {
new ClassLoaderMetrics().bindTo(meterRegistry);
}
if (cmd.hasOption("mjm")) {
new JvmMemoryMetrics().bindTo(meterRegistry);
}
if (cmd.hasOption("mjgc")) {
new JvmGcMetrics().bindTo(meterRegistry);
}
if (cmd.hasOption("mjp")) {
new ProcessorMetrics().bindTo(meterRegistry);
}
if (cmd.hasOption("mjt")) {
new JvmThreadMetrics().bindTo(meterRegistry);
}
}
@Override
public String toString() {
return "Base Metrics";
}
static Collection parseTags(String argument) {
if (argument == null || argument.trim().isEmpty()) {
return Collections.emptyList();
} else {
Collection tags = new ArrayList<>();
for (String tag : argument.split(",")) {
String[] keyValue = tag.split("=", 2);
tags.add(Tag.of(keyValue[0], keyValue[1]));
}
return tags;
}
}
static String commandLineMetrics(String[] args, Options metricsOptions) {
Map filteredOptions = new HashMap<>();
filteredOptions.put("--uri", true);
filteredOptions.put("-h", true);
for (Option option : metricsOptions.getOptions()) {
filteredOptions.put("-" + option.getOpt(), option.hasArg());
if (option.hasLongOpt()) {
filteredOptions.put("--" + option.getLongOpt(), option.hasArg());
}
}
Collection filtered = new ArrayList<>();
Iterator iterator = Arrays.stream(args).iterator();
while (iterator.hasNext()) {
String option = iterator.next();
if (filteredOptions.containsKey(option)) {
if (filteredOptions.get(option)) {
iterator.next();
}
} else {
filtered.add(option);
}
}
return String.join(" ", filtered);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy