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

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