mirror of
https://github.com/musix-org/musix-oss
synced 2025-01-12 12:04:48 +00:00
433 lines
20 KiB
Protocol Buffer
433 lines
20 KiB
Protocol Buffer
// Copyright 2019 Google LLC.
|
|
//
|
|
// 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.
|
|
//
|
|
|
|
syntax = "proto3";
|
|
|
|
package google.monitoring.v3;
|
|
|
|
import "google/api/distribution.proto";
|
|
import "google/protobuf/duration.proto";
|
|
import "google/protobuf/timestamp.proto";
|
|
|
|
option csharp_namespace = "Google.Cloud.Monitoring.V3";
|
|
option go_package = "google.golang.org/genproto/googleapis/monitoring/v3;monitoring";
|
|
option java_multiple_files = true;
|
|
option java_outer_classname = "CommonProto";
|
|
option java_package = "com.google.monitoring.v3";
|
|
option php_namespace = "Google\\Cloud\\Monitoring\\V3";
|
|
|
|
// A single strongly-typed value.
|
|
message TypedValue {
|
|
// The typed value field.
|
|
oneof value {
|
|
// A Boolean value: `true` or `false`.
|
|
bool bool_value = 1;
|
|
|
|
// A 64-bit integer. Its range is approximately ±9.2x10<sup>18</sup>.
|
|
int64 int64_value = 2;
|
|
|
|
// A 64-bit double-precision floating-point number. Its magnitude
|
|
// is approximately ±10<sup>±300</sup> and it has 16
|
|
// significant digits of precision.
|
|
double double_value = 3;
|
|
|
|
// A variable-length string value.
|
|
string string_value = 4;
|
|
|
|
// A distribution value.
|
|
google.api.Distribution distribution_value = 5;
|
|
}
|
|
}
|
|
|
|
// A closed time interval. It extends from the start time to the end time, and includes both: `[startTime, endTime]`. Valid time intervals depend on the [`MetricKind`](/monitoring/api/ref_v3/rest/v3/projects.metricDescriptors#MetricKind) of the metric value. In no case can the end time be earlier than the start time.
|
|
//
|
|
// * For a `GAUGE` metric, the `startTime` value is technically optional; if
|
|
// no value is specified, the start time defaults to the value of the
|
|
// end time, and the interval represents a single point in time. If both
|
|
// start and end times are specified, they must be identical. Such an
|
|
// interval is valid only for `GAUGE` metrics, which are point-in-time
|
|
// measurements.
|
|
//
|
|
// * For `DELTA` and `CUMULATIVE` metrics, the start time must be earlier
|
|
// than the end time.
|
|
//
|
|
// * In all cases, the start time of the next interval must be
|
|
// at least a microsecond after the end time of the previous interval.
|
|
// Because the interval is closed, if the start time of a new interval
|
|
// is the same as the end time of the previous interval, data written
|
|
// at the new start time could overwrite data written at the previous
|
|
// end time.
|
|
message TimeInterval {
|
|
// Required. The end of the time interval.
|
|
google.protobuf.Timestamp end_time = 2;
|
|
|
|
// Optional. The beginning of the time interval. The default value
|
|
// for the start time is the end time. The start time must not be
|
|
// later than the end time.
|
|
google.protobuf.Timestamp start_time = 1;
|
|
}
|
|
|
|
// Describes how to combine multiple time series to provide different views of
|
|
// the data. Aggregation consists of an alignment step on individual time
|
|
// series (`alignment_period` and `per_series_aligner`) followed by an optional
|
|
// reduction step of the data across the aligned time series
|
|
// (`cross_series_reducer` and `group_by_fields`). For more details, see
|
|
// [Aggregation](/monitoring/api/learn_more#aggregation).
|
|
message Aggregation {
|
|
// The Aligner describes how to bring the data points in a single
|
|
// time series into temporal alignment.
|
|
enum Aligner {
|
|
// No alignment. Raw data is returned. Not valid if cross-time
|
|
// series reduction is requested. The value type of the result is
|
|
// the same as the value type of the input.
|
|
ALIGN_NONE = 0;
|
|
|
|
// Align and convert to delta metric type. This alignment is valid
|
|
// for cumulative metrics and delta metrics. Aligning an existing
|
|
// delta metric to a delta metric requires that the alignment
|
|
// period be increased. The value type of the result is the same
|
|
// as the value type of the input.
|
|
//
|
|
// One can think of this aligner as a rate but without time units; that
|
|
// is, the output is conceptually (second_point - first_point).
|
|
ALIGN_DELTA = 1;
|
|
|
|
// Align and convert to a rate. This alignment is valid for
|
|
// cumulative metrics and delta metrics with numeric values. The output is a
|
|
// gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
//
|
|
// One can think of this aligner as conceptually providing the slope of
|
|
// the line that passes through the value at the start and end of the
|
|
// window. In other words, this is conceptually ((y1 - y0)/(t1 - t0)),
|
|
// and the output unit is one that has a "/time" dimension.
|
|
//
|
|
// If, by rate, you are looking for percentage change, see the
|
|
// `ALIGN_PERCENT_CHANGE` aligner option.
|
|
ALIGN_RATE = 2;
|
|
|
|
// Align by interpolating between adjacent points around the
|
|
// period boundary. This alignment is valid for gauge
|
|
// metrics with numeric values. The value type of the result is the same
|
|
// as the value type of the input.
|
|
ALIGN_INTERPOLATE = 3;
|
|
|
|
// Align by shifting the oldest data point before the period
|
|
// boundary to the boundary. This alignment is valid for gauge
|
|
// metrics. The value type of the result is the same as the
|
|
// value type of the input.
|
|
ALIGN_NEXT_OLDER = 4;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the minimum of all data points in the
|
|
// period. This alignment is valid for gauge and delta metrics with numeric
|
|
// values. The value type of the result is the same as the value
|
|
// type of the input.
|
|
ALIGN_MIN = 10;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the maximum of all data points in the
|
|
// period. This alignment is valid for gauge and delta metrics with numeric
|
|
// values. The value type of the result is the same as the value
|
|
// type of the input.
|
|
ALIGN_MAX = 11;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the average or arithmetic mean of all
|
|
// data points in the period. This alignment is valid for gauge and delta
|
|
// metrics with numeric values. The value type of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_MEAN = 12;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the count of all data points in the
|
|
// period. This alignment is valid for gauge and delta metrics with numeric
|
|
// or Boolean values. The value type of the output is
|
|
// [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
ALIGN_COUNT = 13;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the sum of all data points in the
|
|
// period. This alignment is valid for gauge and delta metrics with numeric
|
|
// and distribution values. The value type of the output is the
|
|
// same as the value type of the input.
|
|
ALIGN_SUM = 14;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the standard deviation of all data
|
|
// points in the period. This alignment is valid for gauge and delta metrics
|
|
// with numeric values. The value type of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_STDDEV = 15;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the count of True-valued data points in the
|
|
// period. This alignment is valid for gauge metrics with
|
|
// Boolean values. The value type of the output is
|
|
// [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
ALIGN_COUNT_TRUE = 16;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the count of False-valued data points in the
|
|
// period. This alignment is valid for gauge metrics with
|
|
// Boolean values. The value type of the output is
|
|
// [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
ALIGN_COUNT_FALSE = 24;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the fraction of True-valued data points in the
|
|
// period. This alignment is valid for gauge metrics with Boolean values.
|
|
// The output value is in the range [0, 1] and has value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_FRACTION_TRUE = 17;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the 99th percentile of all data
|
|
// points in the period. This alignment is valid for gauge and delta metrics
|
|
// with distribution values. The output is a gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_PERCENTILE_99 = 18;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the 95th percentile of all data
|
|
// points in the period. This alignment is valid for gauge and delta metrics
|
|
// with distribution values. The output is a gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_PERCENTILE_95 = 19;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the 50th percentile of all data
|
|
// points in the period. This alignment is valid for gauge and delta metrics
|
|
// with distribution values. The output is a gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_PERCENTILE_50 = 20;
|
|
|
|
// Align time series via aggregation. The resulting data point in
|
|
// the alignment period is the 5th percentile of all data
|
|
// points in the period. This alignment is valid for gauge and delta metrics
|
|
// with distribution values. The output is a gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_PERCENTILE_05 = 21;
|
|
|
|
// Align and convert to a percentage change. This alignment is valid for
|
|
// gauge and delta metrics with numeric values. This alignment conceptually
|
|
// computes the equivalent of "((current - previous)/previous)*100"
|
|
// where previous value is determined based on the alignmentPeriod.
|
|
// In the event that previous is 0 the calculated value is infinity with the
|
|
// exception that if both (current - previous) and previous are 0 the
|
|
// calculated value is 0.
|
|
// A 10 minute moving mean is computed at each point of the time window
|
|
// prior to the above calculation to smooth the metric and prevent false
|
|
// positives from very short lived spikes.
|
|
// Only applicable for data that is >= 0. Any values < 0 are treated as
|
|
// no data. While delta metrics are accepted by this alignment special care
|
|
// should be taken that the values for the metric will always be positive.
|
|
// The output is a gauge metric with value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
ALIGN_PERCENT_CHANGE = 23;
|
|
}
|
|
|
|
// A Reducer describes how to aggregate data points from multiple
|
|
// time series into a single time series.
|
|
enum Reducer {
|
|
// No cross-time series reduction. The output of the aligner is
|
|
// returned.
|
|
REDUCE_NONE = 0;
|
|
|
|
// Reduce by computing the mean across time series for each
|
|
// alignment period. This reducer is valid for delta and
|
|
// gauge metrics with numeric or distribution values. The value type of the
|
|
// output is [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
REDUCE_MEAN = 1;
|
|
|
|
// Reduce by computing the minimum across time series for each
|
|
// alignment period. This reducer is valid for delta and
|
|
// gauge metrics with numeric values. The value type of the output
|
|
// is the same as the value type of the input.
|
|
REDUCE_MIN = 2;
|
|
|
|
// Reduce by computing the maximum across time series for each
|
|
// alignment period. This reducer is valid for delta and
|
|
// gauge metrics with numeric values. The value type of the output
|
|
// is the same as the value type of the input.
|
|
REDUCE_MAX = 3;
|
|
|
|
// Reduce by computing the sum across time series for each
|
|
// alignment period. This reducer is valid for delta and
|
|
// gauge metrics with numeric and distribution values. The value type of
|
|
// the output is the same as the value type of the input.
|
|
REDUCE_SUM = 4;
|
|
|
|
// Reduce by computing the standard deviation across time series
|
|
// for each alignment period. This reducer is valid for delta
|
|
// and gauge metrics with numeric or distribution values. The value type of
|
|
// the output is [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
REDUCE_STDDEV = 5;
|
|
|
|
// Reduce by computing the count of data points across time series
|
|
// for each alignment period. This reducer is valid for delta
|
|
// and gauge metrics of numeric, Boolean, distribution, and string value
|
|
// type. The value type of the output is
|
|
// [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
REDUCE_COUNT = 6;
|
|
|
|
// Reduce by computing the count of True-valued data points across time
|
|
// series for each alignment period. This reducer is valid for delta
|
|
// and gauge metrics of Boolean value type. The value type of
|
|
// the output is [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
REDUCE_COUNT_TRUE = 7;
|
|
|
|
// Reduce by computing the count of False-valued data points across time
|
|
// series for each alignment period. This reducer is valid for delta
|
|
// and gauge metrics of Boolean value type. The value type of
|
|
// the output is [INT64][google.api.MetricDescriptor.ValueType.INT64].
|
|
REDUCE_COUNT_FALSE = 15;
|
|
|
|
// Reduce by computing the fraction of True-valued data points across time
|
|
// series for each alignment period. This reducer is valid for delta
|
|
// and gauge metrics of Boolean value type. The output value is in the
|
|
// range [0, 1] and has value type
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE].
|
|
REDUCE_FRACTION_TRUE = 8;
|
|
|
|
// Reduce by computing 99th percentile of data points across time series
|
|
// for each alignment period. This reducer is valid for gauge and delta
|
|
// metrics of numeric and distribution type. The value of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE]
|
|
REDUCE_PERCENTILE_99 = 9;
|
|
|
|
// Reduce by computing 95th percentile of data points across time series
|
|
// for each alignment period. This reducer is valid for gauge and delta
|
|
// metrics of numeric and distribution type. The value of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE]
|
|
REDUCE_PERCENTILE_95 = 10;
|
|
|
|
// Reduce by computing 50th percentile of data points across time series
|
|
// for each alignment period. This reducer is valid for gauge and delta
|
|
// metrics of numeric and distribution type. The value of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE]
|
|
REDUCE_PERCENTILE_50 = 11;
|
|
|
|
// Reduce by computing 5th percentile of data points across time series
|
|
// for each alignment period. This reducer is valid for gauge and delta
|
|
// metrics of numeric and distribution type. The value of the output is
|
|
// [DOUBLE][google.api.MetricDescriptor.ValueType.DOUBLE]
|
|
REDUCE_PERCENTILE_05 = 12;
|
|
}
|
|
|
|
// The alignment period for per-[time series][google.monitoring.v3.TimeSeries]
|
|
// alignment. If present, `alignmentPeriod` must be at least 60
|
|
// seconds. After per-time series alignment, each time series will
|
|
// contain data points only on the period boundaries. If
|
|
// `perSeriesAligner` is not specified or equals `ALIGN_NONE`, then
|
|
// this field is ignored. If `perSeriesAligner` is specified and
|
|
// does not equal `ALIGN_NONE`, then this field must be defined;
|
|
// otherwise an error is returned.
|
|
google.protobuf.Duration alignment_period = 1;
|
|
|
|
// The approach to be used to align individual time series. Not all
|
|
// alignment functions may be applied to all time series, depending
|
|
// on the metric type and value type of the original time
|
|
// series. Alignment may change the metric type or the value type of
|
|
// the time series.
|
|
//
|
|
// Time series data must be aligned in order to perform cross-time
|
|
// series reduction. If `crossSeriesReducer` is specified, then
|
|
// `perSeriesAligner` must be specified and not equal `ALIGN_NONE`
|
|
// and `alignmentPeriod` must be specified; otherwise, an error is
|
|
// returned.
|
|
Aligner per_series_aligner = 2;
|
|
|
|
// The approach to be used to combine time series. Not all reducer
|
|
// functions may be applied to all time series, depending on the
|
|
// metric type and the value type of the original time
|
|
// series. Reduction may change the metric type of value type of the
|
|
// time series.
|
|
//
|
|
// Time series data must be aligned in order to perform cross-time
|
|
// series reduction. If `crossSeriesReducer` is specified, then
|
|
// `perSeriesAligner` must be specified and not equal `ALIGN_NONE`
|
|
// and `alignmentPeriod` must be specified; otherwise, an error is
|
|
// returned.
|
|
Reducer cross_series_reducer = 4;
|
|
|
|
// The set of fields to preserve when `crossSeriesReducer` is
|
|
// specified. The `groupByFields` determine how the time series are
|
|
// partitioned into subsets prior to applying the aggregation
|
|
// function. Each subset contains time series that have the same
|
|
// value for each of the grouping fields. Each individual time
|
|
// series is a member of exactly one subset. The
|
|
// `crossSeriesReducer` is applied to each subset of time series.
|
|
// It is not possible to reduce across different resource types, so
|
|
// this field implicitly contains `resource.type`. Fields not
|
|
// specified in `groupByFields` are aggregated away. If
|
|
// `groupByFields` is not specified and all the time series have
|
|
// the same resource type, then the time series are aggregated into
|
|
// a single output time series. If `crossSeriesReducer` is not
|
|
// defined, this field is ignored.
|
|
repeated string group_by_fields = 5;
|
|
}
|
|
|
|
// Specifies an ordering relationship on two arguments, here called left and
|
|
// right.
|
|
enum ComparisonType {
|
|
// No ordering relationship is specified.
|
|
COMPARISON_UNSPECIFIED = 0;
|
|
|
|
// The left argument is greater than the right argument.
|
|
COMPARISON_GT = 1;
|
|
|
|
// The left argument is greater than or equal to the right argument.
|
|
COMPARISON_GE = 2;
|
|
|
|
// The left argument is less than the right argument.
|
|
COMPARISON_LT = 3;
|
|
|
|
// The left argument is less than or equal to the right argument.
|
|
COMPARISON_LE = 4;
|
|
|
|
// The left argument is equal to the right argument.
|
|
COMPARISON_EQ = 5;
|
|
|
|
// The left argument is not equal to the right argument.
|
|
COMPARISON_NE = 6;
|
|
}
|
|
|
|
// The tier of service for a Workspace. Please see the
|
|
// [service tiers
|
|
// documentation](https://cloud.google.com/monitoring/workspaces/tiers) for more
|
|
// details.
|
|
enum ServiceTier {
|
|
option deprecated = true;
|
|
|
|
// An invalid sentinel value, used to indicate that a tier has not
|
|
// been provided explicitly.
|
|
SERVICE_TIER_UNSPECIFIED = 0;
|
|
|
|
// The Stackdriver Basic tier, a free tier of service that provides basic
|
|
// features, a moderate allotment of logs, and access to built-in metrics.
|
|
// A number of features are not available in this tier. For more details,
|
|
// see [the service tiers
|
|
// documentation](https://cloud.google.com/monitoring/workspaces/tiers).
|
|
SERVICE_TIER_BASIC = 1;
|
|
|
|
// The Stackdriver Premium tier, a higher, more expensive tier of service
|
|
// that provides access to all Stackdriver features, lets you use Stackdriver
|
|
// with AWS accounts, and has a larger allotments for logs and metrics. For
|
|
// more details, see [the service tiers
|
|
// documentation](https://cloud.google.com/monitoring/workspaces/tiers).
|
|
SERVICE_TIER_PREMIUM = 2;
|
|
}
|