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

ai.vespa.metricsproxy.metric.dimensions.PublicDimensions Maven / Gradle / Ivy

There is a newer version: 8.441.21
Show newest version
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package ai.vespa.metricsproxy.metric.dimensions;

import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * The names of all dimensions that are publicly available, in addition to some dimensions that
 * are used in the process of composing these public dimensions.
 *
 * 'INTERNAL' in this context means non-public.
 *
 * @author gjoranv
 */
public final class PublicDimensions {
    private PublicDimensions() { }

    public static final String APPLICATION_ID = "applicationId";  // 
    public static final String ZONE = "zone";

    // The public CLUSTER_ID dimension value is composed from the two non-public dimensions.
    // Node-specific.
    public static final String INTERNAL_CLUSTER_TYPE = "clustertype";
    public static final String INTERNAL_CLUSTER_ID = "clusterid";
    public static final String CLUSTER_ID = "clusterId";
    public static final String DEPLOYMENT_CLUSTER = "deploymentCluster";

    // This dimension is not currently (March 2021) added to the 'commonDimensions' allow-list below, due to the
    // limit of 10 total dimensions in public http apis. See e.g. MetricsV2Handler#MAX_DIMENSIONS.
    public static final String GROUP_ID = "groupId";

    // Internal name (instance) is confusing, so renamed to 'serviceId' for public use.
    // This is added by the metrics-proxy.
    public static final String INTERNAL_SERVICE_ID = "instance";
    public static final String SERVICE_ID = "serviceId";

    // From host-admin, currently (Jan 2020) only included for 'vespa.node' metrics
    public static final String HOSTNAME = "host";


    /**  Metric specific dimensions  **/
    public static final String API = "api";                                 // feed
    public static final String CHAIN = "chain";                             // query
    public static final String DOCUMENT_TYPE = "documenttype";              // content
    public static final String ENDPOINT = "endpoint";                       // query
    public static final String GC_NAME = "gcName";                          // container
    public static final String HTTP_METHOD = "httpMethod";                  // container
    public static final String OPERATION = "operation";                     // feed
    public static final String RANK_PROFILE = "rankProfile";                // content
    public static final String REASON = "reason";                           // query (degraded etc.)
    public static final String STATUS = "status";                           // feed
    public static final String THREADPOOL = "threadpool";                   // container
    private static final String LOGLEVEL = "loglevel";                      // log line metrics
    private static final String SERVICE = "service";                        // log line metrics
    private static final String CHAIN_ID = "chainId";                       // container
    private static final String REQUEST_SERVER_NAME = "requestServerName";  // container
    public static final String HANDLER_NAME = "handler-name";               // container
    public static final String FIELD = "field";                             // content


    // Dimensions that are valid (but not necessarily used) for all metrics.
    public static List commonDimensions =
            List.of(APPLICATION_ID,
                    CLUSTER_ID,
                    HOSTNAME,
                    SERVICE_ID,
                    ZONE);

    // Dimensions that are only used for a subset of metrics.
    public static List metricDimensions =
        List.of(API,
                CHAIN,
                DOCUMENT_TYPE,
                ENDPOINT,
                GC_NAME,
                HTTP_METHOD,
                OPERATION,
                RANK_PROFILE,
                REASON,
                STATUS,
                THREADPOOL,
                LOGLEVEL,
                SERVICE,
                CHAIN_ID,
                REQUEST_SERVER_NAME,
                HANDLER_NAME);


    /**
     * All public dimensions, common dimensions first, then dimensions for individual metrics
     */
    public static final List publicDimensions = Stream.concat(commonDimensions.stream(), metricDimensions.stream())
            .toList();

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy