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

org.glowroot.storage.repo.TraceRepository Maven / Gradle / Ivy

There is a newer version: 0.9.28
Show newest version
/*
 * Copyright 2015 the original author or 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 org.glowroot.storage.repo;

import java.util.List;

import javax.annotation.Nullable;

import org.glowroot.agent.shaded.google.common.collect.ImmutableList;
import org.immutables.value.Value;

import org.glowroot.common.live.LiveTraceRepository.Existence;
import org.glowroot.common.live.LiveTraceRepository.TracePoint;
import org.glowroot.common.live.LiveTraceRepository.TracePointQuery;
import org.glowroot.common.util.Styles;
import org.glowroot.wire.api.model.ProfileTreeOuterClass.ProfileTree;
import org.glowroot.wire.api.model.TraceOuterClass.Trace;

public interface TraceRepository {

    void collect(String serverId, Trace trace) throws Exception;

    List readTraceAttributeNames(String serverRollup) throws Exception;

    Result readPoints(TracePointQuery query) throws Exception;

    long readOverallSlowCount(String serverRollup, String transactionType, long captureTimeFrom,
            long captureTimeTo) throws Exception;

    long readTransactionSlowCount(String serverRollup, String transactionType,
            String transactionName, long captureTimeFrom, long captureTimeTo) throws Exception;

    long readOverallErrorCount(String serverRollup, String transactionType, long captureTimeFrom,
            long captureTimeTo) throws Exception;

    long readTransactionErrorCount(String serverRollup, String transactionType,
            String transactionName, long captureTimeFrom, long captureTimeTo) throws Exception;

    List readErrorPoints(ErrorMessageQuery query, long resolutionMillis,
            long liveCaptureTime) throws Exception;

    Result readErrorMessageCounts(ErrorMessageQuery query) throws Exception;

    @Nullable
    HeaderPlus readHeader(String serverId, String traceId) throws Exception;

    List readEntries(String serverId, String traceId) throws Exception;

    @Nullable
    ProfileTree readProfileTree(String serverId, String traceId) throws Exception;

    void deleteAll(String serverRollup) throws Exception;

    long count(String serverRollup) throws Exception;

    @Value.Immutable
    public interface ErrorMessageCount {
        String message();
        long count();
    }

    @Value.Immutable
    public interface ErrorMessageQuery {
        String serverRollup();
        String transactionType();
        @Nullable
        String transactionName();
        long from();
        long to();
        ImmutableList includes();
        ImmutableList excludes();
        int limit();
    }

    @Value.Immutable
    @Styles.AllParameters
    public interface TraceErrorPoint {
        long captureTime();
        long errorCount();
    }

    @Value.Immutable
    @Styles.AllParameters
    public interface HeaderPlus {
        Trace.Header header();
        Existence entriesExistence();
        Existence profileExistence();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy