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

com.azure.cosmos.CosmosDiagnosticsRequestEvent Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.cosmos;

import java.time.Duration;
import java.time.Instant;

import static com.azure.cosmos.implementation.guava25.base.Preconditions.checkNotNull;

/**
 * This class represents diagnostic information for different steps in the request pipeline when
 * processing a data plane request (for example to issue a point operation against a certain replica). This information
 * can be useful to identify where in the request pipeline an error happened or latency was spent - for example whether
 * high latency was due to the fact that a new channel (TCP connection with SSL handshake) needed to be created
 * or because the transport took a long time due to network issues etc.
 */
public final class CosmosDiagnosticsRequestEvent {

    private final Instant startTime;
    private final Duration duration;
    private final String name;

    CosmosDiagnosticsRequestEvent(
        Instant startTime,
        Duration duration,
        String name) {

        checkNotNull(startTime, "Argument 'startTime' must not be null.");
        checkNotNull(name, "Argument 'name' must not be null.");
        this.startTime = startTime;
        this.duration = duration;
        this.name = name;
    }

    /**
     * Gets the start time of the request pipeline event
     * @return the start time of the request pipeline event
     */
    public Instant getStartTime() {
        return this.startTime;
    }

    /**
     * Gets the duration for the request pipeline event - or null when the pipeline event hasn't finished (yet).
     * @return the duration for the request pipeline event or null when the pipeline event hasn't finished (yet).
     */
    public Duration getDuration() {
        return this.duration;
    }

    /**
     * Gets the name of the request pipeline event.
     * @return the name of the request pipeline event.
     */
    public String getEventName() {
        return this.name;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy