/** * Copyright 2015-2016 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 zipkin.collector; import java.util.List; import zipkin.Component; import zipkin.Span; import zipkin.storage.AsyncSpanConsumer; import zipkin.storage.Callback; import zipkin.storage.StorageComponent; /** * The collector represents the server-side of a transport. Its job is to take spans from a * transport and store ones it has sampled. * * <p>Call {@link #start()} to start collecting spans. */ public interface CollectorComponent extends Component { /** * Starts the server-side of the transport, typically listening or looking up a queue. * * <p>Many implementations block the calling thread until services are available. */ CollectorComponent start(); interface Builder { /** * Once spans are sampled, they are {@link AsyncSpanConsumer#accept(List, Callback) queued for * storage} using this component. */ Builder storage(StorageComponent storage); /** * Aggregates and reports collection metrics to a monitoring system. Should be {@link * CollectorMetrics#forTransport(String) scoped to this transport}. Defaults to no-op. */ Builder metrics(CollectorMetrics metrics); /** * {@link CollectorSampler#isSampled(Span) samples spans} to reduce load on the storage system. * Defaults to always sample. */ Builder sampler(CollectorSampler sampler); CollectorComponent build(); } }