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

brave.sampler.Sampler Maven / Gradle / Ivy

There is a newer version: 6.0.3
Show newest version
/*
 * Copyright 2013-2019 The OpenZipkin Authors
 *
 * 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 brave.sampler;

/**
 * Sampler is responsible for deciding if a particular trace should be "sampled", i.e. whether the
 * overhead of tracing will occur and/or if a trace will be reported to the collection tier.
 *
 * 

Zipkin v1 uses before-the-fact sampling. This means that the decision to keep or drop the * trace is made before any work is measured, or annotations are added. As such, the input parameter * to zipkin v1 samplers is the trace ID (lower 64-bits under the assumption all bits are random). * *

The instrumentation sampling decision happens once, at the root of the trace, and is * propagated downstream. For this reason, the algorithm needn't be consistent based on trace ID. */ // abstract for factory-method support on Java language level 7 public abstract class Sampler { public static final Sampler ALWAYS_SAMPLE = new Sampler() { @Override public boolean isSampled(long traceId) { return true; } @Override public String toString() { return "AlwaysSample"; } }; public static final Sampler NEVER_SAMPLE = new Sampler() { @Override public boolean isSampled(long traceId) { return false; } @Override public String toString() { return "NeverSample"; } }; /** * Returns true if the trace ID should be measured. * * @param traceId The trace ID to be decided on, can be ignored */ public abstract boolean isSampled(long traceId); /** * Returns a sampler, given a probability expressed as a percentage. * *

The sampler returned is good for low volumes of traffic (<100K requests), as it is precise. * If you have high volumes of traffic, consider {@link BoundarySampler}. * * @param probability probability a trace will be sampled. minimum is 0.01, or 1% of traces */ public static Sampler create(float probability) { return CountingSampler.create(probability); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy