org.apache.jackrabbit.oak.run.IOTraceCommand Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.jackrabbit.oak.run;
import static java.lang.String.format;
import static org.apache.jackrabbit.oak.run.Traces.BREADTH;
import static org.apache.jackrabbit.oak.run.Traces.DEFAULT_COUNT;
import static org.apache.jackrabbit.oak.run.Traces.DEFAULT_DEPTH;
import static org.apache.jackrabbit.oak.run.Traces.DEFAULT_PATH;
import static org.apache.jackrabbit.oak.run.Traces.DEFAULT_SEED;
import static org.apache.jackrabbit.oak.run.Traces.DEPTH;
import static org.apache.jackrabbit.oak.run.Traces.RANDOM;
import static org.apache.jackrabbit.oak.segment.FileStoreHelper.isValidFileStoreOrFail;
import java.io.File;
import java.io.IOException;
import java.io.PrintStream;
import java.util.Arrays;
import joptsimple.ArgumentAcceptingOptionSpec;
import joptsimple.OptionException;
import joptsimple.OptionParser;
import joptsimple.OptionSet;
import org.apache.jackrabbit.oak.run.commons.Command;
import org.apache.jackrabbit.oak.segment.tool.iotrace.IOTracer;
import org.jetbrains.annotations.NotNull;
/**
* Command line utility for collection {@link IOTracer io traces}
*
usage: iotrace path/to/segmentstore
Option (* = required) Description
--------------------- -----------
--depth Maximal depth of the traversal (default: 5)
--mmap use memory mapping for the file store (default: true)
--output output file where the IO trace is written to (default: iotrace.csv)
--path starting path for the traversal (default: /root)
--segment-cache size of the segment cache in MB (default: 256)
--trace (*) type of the traversal. Either of [DEPTH, BREADTH]
*/
class IOTraceCommand implements Command {
public static final String NAME = "iotrace";
@Override
public void execute(String... args) throws Exception {
OptionParser optionParser = new OptionParser();
ArgumentAcceptingOptionSpec traceOption = optionParser
.accepts("trace", "type of the traversal. Either of " + Arrays.toString(Traces.values()))
.withRequiredArg()
.ofType(Traces.class)
.required();
ArgumentAcceptingOptionSpec outputOption = optionParser
.accepts("output", "output file where the IO trace is written to")
.withRequiredArg()
.ofType(File.class)
.defaultsTo(new File("iotrace.csv"));
ArgumentAcceptingOptionSpec mmapOption = optionParser
.accepts("mmap", "use memory mapping for the file store")
.withRequiredArg()
.ofType(Boolean.class)
.defaultsTo(true);
ArgumentAcceptingOptionSpec segmentCacheOption = optionParser
.accepts("segment-cache", "size of the segment cache in MB")
.withRequiredArg()
.ofType(Integer.class)
.defaultsTo(256);
ArgumentAcceptingOptionSpec depthOption = optionParser
.accepts("depth", "Maximal depth of the traversal." +
" Applies to " + BREADTH + ", " + DEPTH)
.withRequiredArg()
.ofType(Integer.class)
.defaultsTo(DEFAULT_DEPTH);
ArgumentAcceptingOptionSpec pathOption = optionParser
.accepts("path", "starting path for the traversal." +
" Applies to " + BREADTH + ", " + DEPTH)
.withRequiredArg()
.ofType(String.class)
.defaultsTo(DEFAULT_PATH);
ArgumentAcceptingOptionSpec pathsOption = optionParser
.accepts("paths", "file containing list of paths to traverse." +
" Applies to " + RANDOM)
.withRequiredArg()
.ofType(File.class)
.defaultsTo(new File("paths.txt"));
ArgumentAcceptingOptionSpec seedOption = optionParser
.accepts("seed", "Seed for generating random numbers." +
" Applies to " + RANDOM)
.withRequiredArg()
.ofType(Long.class)
.defaultsTo(DEFAULT_SEED);
ArgumentAcceptingOptionSpec countOption = optionParser
.accepts("count", "Number of paths to access" +
" Applies to " + RANDOM)
.withRequiredArg()
.ofType(Integer.class)
.defaultsTo(DEFAULT_COUNT);
try {
OptionSet options = optionParser.parse(args);
if (options.nonOptionArguments().size() != 1) {
printUsage(optionParser, System.err);
System.exit(1);
}
File segmentStore = isValidFileStoreOrFail(new File(options.nonOptionArguments().get(0).toString()));
Boolean mmap = mmapOption.value(options);
Integer segmentCache = segmentCacheOption.value(options);
File output = outputOption.value(options);
Traces trace = traceOption.value(options);
trace.setPath(pathOption.value(options));
trace.setDepth(depthOption.value(options));
trace.setPaths(pathsOption.value(options));
trace.setSeed(seedOption.value(options));
trace.setCount(countOption.value(options));
System.out.println(
format("tracing %s with %s", segmentStore, trace.getDescription()));
System.out.println(
format("mmap=%b, segment cache=%d", mmap, segmentCache));
System.out.println(
format("Writing trace to %s", output));
trace.collectIOTrace(segmentStore, mmap, segmentCache, output);
} catch (OptionException e) {
printUsage(optionParser, System.err, e.getMessage());
System.exit(1);
}
}
private static void printUsage(
@NotNull OptionParser parser,
@NotNull PrintStream err,
@NotNull String... messages)
throws IOException {
for (String message : messages) {
err.println(message);
}
err.println("usage: " + NAME + " path/to/segmentstore ");
parser.printHelpOn(err);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy