You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
335 lines
12 KiB
335 lines
12 KiB
// Copyright 2017 Google Inc.
|
|
//
|
|
// 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.devtools.cloudtrace.v2;
|
|
|
|
import "google/api/annotations.proto";
|
|
import "google/protobuf/timestamp.proto";
|
|
import "google/protobuf/wrappers.proto";
|
|
import "google/rpc/status.proto";
|
|
|
|
option csharp_namespace = "Google.Cloud.Trace.V2";
|
|
option go_package = "google.golang.org/genproto/googleapis/devtools/cloudtrace/v2;cloudtrace";
|
|
option java_multiple_files = true;
|
|
option java_outer_classname = "TraceProto";
|
|
option java_package = "com.google.devtools.cloudtrace.v2";
|
|
option php_namespace = "Google\\Cloud\\Trace\\V2";
|
|
|
|
// A span represents a single operation within a trace. Spans can be
|
|
// nested to form a trace tree. Often, a trace contains a root span
|
|
// that describes the end-to-end latency, and one or more subspans for
|
|
// its sub-operations. A trace can also contain multiple root spans,
|
|
// or none at all. Spans do not need to be contiguous—there may be
|
|
// gaps or overlaps between spans in a trace.
|
|
message Span {
|
|
// A set of attributes, each in the format `[KEY]:[VALUE]`.
|
|
message Attributes {
|
|
// The set of attributes. Each attribute's key can be up to 128 bytes
|
|
// long. The value can be a string up to 256 bytes, an integer, or the
|
|
// Boolean values `true` and `false`. For example:
|
|
//
|
|
// "/instance_id": "my-instance"
|
|
// "/http/user_agent": ""
|
|
// "/http/request_bytes": 300
|
|
// "abc.com/myattribute": true
|
|
map<string, AttributeValue> attribute_map = 1;
|
|
|
|
// The number of attributes that were discarded. Attributes can be discarded
|
|
// because their keys are too long or because there are too many attributes.
|
|
// If this value is 0 then all attributes are valid.
|
|
int32 dropped_attributes_count = 2;
|
|
}
|
|
|
|
// A time-stamped annotation or message event in the Span.
|
|
message TimeEvent {
|
|
// Text annotation with a set of attributes.
|
|
message Annotation {
|
|
// A user-supplied message describing the event. The maximum length for
|
|
// the description is 256 bytes.
|
|
TruncatableString description = 1;
|
|
|
|
// A set of attributes on the annotation. You can have up to 4 attributes
|
|
// per Annotation.
|
|
Attributes attributes = 2;
|
|
}
|
|
|
|
// An event describing a message sent/received between Spans.
|
|
message MessageEvent {
|
|
// Indicates whether the message was sent or received.
|
|
enum Type {
|
|
// Unknown event type.
|
|
TYPE_UNSPECIFIED = 0;
|
|
|
|
// Indicates a sent message.
|
|
SENT = 1;
|
|
|
|
// Indicates a received message.
|
|
RECEIVED = 2;
|
|
}
|
|
|
|
// Type of MessageEvent. Indicates whether the message was sent or
|
|
// received.
|
|
Type type = 1;
|
|
|
|
// An identifier for the MessageEvent's message that can be used to match
|
|
// SENT and RECEIVED MessageEvents. It is recommended to be unique within
|
|
// a Span.
|
|
int64 id = 2;
|
|
|
|
// The number of uncompressed bytes sent or received.
|
|
int64 uncompressed_size_bytes = 3;
|
|
|
|
// The number of compressed bytes sent or received. If missing assumed to
|
|
// be the same size as uncompressed.
|
|
int64 compressed_size_bytes = 4;
|
|
}
|
|
|
|
// The timestamp indicating the time the event occurred.
|
|
google.protobuf.Timestamp time = 1;
|
|
|
|
// A `TimeEvent` can contain either an `Annotation` object or a
|
|
// `MessageEvent` object, but not both.
|
|
oneof value {
|
|
// Text annotation with a set of attributes.
|
|
Annotation annotation = 2;
|
|
|
|
// An event describing a message sent/received between Spans.
|
|
MessageEvent message_event = 3;
|
|
}
|
|
}
|
|
|
|
// A collection of `TimeEvent`s. A `TimeEvent` is a time-stamped annotation
|
|
// on the span, consisting of either user-supplied key:value pairs, or
|
|
// details of a message sent/received between Spans.
|
|
message TimeEvents {
|
|
// A collection of `TimeEvent`s.
|
|
repeated TimeEvent time_event = 1;
|
|
|
|
// The number of dropped annotations in all the included time events.
|
|
// If the value is 0, then no annotations were dropped.
|
|
int32 dropped_annotations_count = 2;
|
|
|
|
// The number of dropped message events in all the included time events.
|
|
// If the value is 0, then no message events were dropped.
|
|
int32 dropped_message_events_count = 3;
|
|
}
|
|
|
|
// A pointer from the current span to another span in the same trace or in a
|
|
// different trace. For example, this can be used in batching operations,
|
|
// where a single batch handler processes multiple requests from different
|
|
// traces or when the handler receives a request from a different project.
|
|
message Link {
|
|
// The relationship of the current span relative to the linked span: child,
|
|
// parent, or unspecified.
|
|
enum Type {
|
|
// The relationship of the two spans is unknown.
|
|
TYPE_UNSPECIFIED = 0;
|
|
|
|
// The linked span is a child of the current span.
|
|
CHILD_LINKED_SPAN = 1;
|
|
|
|
// The linked span is a parent of the current span.
|
|
PARENT_LINKED_SPAN = 2;
|
|
}
|
|
|
|
// The [TRACE_ID] for a trace within a project.
|
|
string trace_id = 1;
|
|
|
|
// The [SPAN_ID] for a span within a trace.
|
|
string span_id = 2;
|
|
|
|
// The relationship of the current span relative to the linked span.
|
|
Type type = 3;
|
|
|
|
// A set of attributes on the link. You have have up to 32 attributes per
|
|
// link.
|
|
Attributes attributes = 4;
|
|
}
|
|
|
|
// A collection of links, which are references from this span to a span
|
|
// in the same or different trace.
|
|
message Links {
|
|
// A collection of links.
|
|
repeated Link link = 1;
|
|
|
|
// The number of dropped links after the maximum size was enforced. If
|
|
// this value is 0, then no links were dropped.
|
|
int32 dropped_links_count = 2;
|
|
}
|
|
|
|
// The resource name of the span in the following format:
|
|
//
|
|
// projects/[PROJECT_ID]/traces/[TRACE_ID]/spans/[SPAN_ID]
|
|
//
|
|
// [TRACE_ID] is a unique identifier for a trace within a project;
|
|
// it is a 32-character hexadecimal encoding of a 16-byte array.
|
|
//
|
|
// [SPAN_ID] is a unique identifier for a span within a trace; it
|
|
// is a 16-character hexadecimal encoding of an 8-byte array.
|
|
string name = 1;
|
|
|
|
// The [SPAN_ID] portion of the span's resource name.
|
|
string span_id = 2;
|
|
|
|
// The [SPAN_ID] of this span's parent span. If this is a root span,
|
|
// then this field must be empty.
|
|
string parent_span_id = 3;
|
|
|
|
// A description of the span's operation (up to 128 bytes).
|
|
// Stackdriver Trace displays the description in the
|
|
// {% dynamic print site_values.console_name %}.
|
|
// For example, the display name can be a qualified method name or a file name
|
|
// and a line number where the operation is called. A best practice is to use
|
|
// the same display name within an application and at the same call point.
|
|
// This makes it easier to correlate spans in different traces.
|
|
TruncatableString display_name = 4;
|
|
|
|
// The start time of the span. On the client side, this is the time kept by
|
|
// the local machine where the span execution starts. On the server side, this
|
|
// is the time when the server's application handler starts running.
|
|
google.protobuf.Timestamp start_time = 5;
|
|
|
|
// The end time of the span. On the client side, this is the time kept by
|
|
// the local machine where the span execution ends. On the server side, this
|
|
// is the time when the server application handler stops running.
|
|
google.protobuf.Timestamp end_time = 6;
|
|
|
|
// A set of attributes on the span. You can have up to 32 attributes per
|
|
// span.
|
|
Attributes attributes = 7;
|
|
|
|
// Stack trace captured at the start of the span.
|
|
StackTrace stack_trace = 8;
|
|
|
|
// A set of time events. You can have up to 32 annotations and 128 message
|
|
// events per span.
|
|
TimeEvents time_events = 9;
|
|
|
|
// Links associated with the span. You can have up to 128 links per Span.
|
|
Links links = 10;
|
|
|
|
// An optional final status for this span.
|
|
google.rpc.Status status = 11;
|
|
|
|
// (Optional) Set this parameter to indicate whether this span is in
|
|
// the same process as its parent. If you do not set this parameter,
|
|
// Stackdriver Trace is unable to take advantage of this helpful
|
|
// information.
|
|
google.protobuf.BoolValue same_process_as_parent_span = 12;
|
|
|
|
// An optional number of child spans that were generated while this span
|
|
// was active. If set, allows implementation to detect missing child spans.
|
|
google.protobuf.Int32Value child_span_count = 13;
|
|
}
|
|
|
|
// The allowed types for [VALUE] in a `[KEY]:[VALUE]` attribute.
|
|
message AttributeValue {
|
|
// The type of the value.
|
|
oneof value {
|
|
// A string up to 256 bytes long.
|
|
TruncatableString string_value = 1;
|
|
|
|
// A 64-bit signed integer.
|
|
int64 int_value = 2;
|
|
|
|
// A Boolean value represented by `true` or `false`.
|
|
bool bool_value = 3;
|
|
}
|
|
}
|
|
|
|
// A call stack appearing in a trace.
|
|
message StackTrace {
|
|
// Represents a single stack frame in a stack trace.
|
|
message StackFrame {
|
|
// The fully-qualified name that uniquely identifies the function or
|
|
// method that is active in this frame (up to 1024 bytes).
|
|
TruncatableString function_name = 1;
|
|
|
|
// An un-mangled function name, if `function_name` is
|
|
// [mangled](http://www.avabodh.com/cxxin/namemangling.html). The name can
|
|
// be fully-qualified (up to 1024 bytes).
|
|
TruncatableString original_function_name = 2;
|
|
|
|
// The name of the source file where the function call appears (up to 256
|
|
// bytes).
|
|
TruncatableString file_name = 3;
|
|
|
|
// The line number in `file_name` where the function call appears.
|
|
int64 line_number = 4;
|
|
|
|
// The column number where the function call appears, if available.
|
|
// This is important in JavaScript because of its anonymous functions.
|
|
int64 column_number = 5;
|
|
|
|
// The binary module from where the code was loaded.
|
|
Module load_module = 6;
|
|
|
|
// The version of the deployed source code (up to 128 bytes).
|
|
TruncatableString source_version = 7;
|
|
}
|
|
|
|
// A collection of stack frames, which can be truncated.
|
|
message StackFrames {
|
|
// Stack frames in this call stack.
|
|
repeated StackFrame frame = 1;
|
|
|
|
// The number of stack frames that were dropped because there
|
|
// were too many stack frames.
|
|
// If this value is 0, then no stack frames were dropped.
|
|
int32 dropped_frames_count = 2;
|
|
}
|
|
|
|
// Stack frames in this stack trace. A maximum of 128 frames are allowed.
|
|
StackFrames stack_frames = 1;
|
|
|
|
// The hash ID is used to conserve network bandwidth for duplicate
|
|
// stack traces within a single trace.
|
|
//
|
|
// Often multiple spans will have identical stack traces.
|
|
// The first occurrence of a stack trace should contain both the
|
|
// `stackFrame` content and a value in `stackTraceHashId`.
|
|
//
|
|
// Subsequent spans within the same request can refer
|
|
// to that stack trace by only setting `stackTraceHashId`.
|
|
int64 stack_trace_hash_id = 2;
|
|
}
|
|
|
|
// Binary module.
|
|
message Module {
|
|
// For example: main binary, kernel modules, and dynamic libraries
|
|
// such as libc.so, sharedlib.so (up to 256 bytes).
|
|
TruncatableString module = 1;
|
|
|
|
// A unique identifier for the module, usually a hash of its
|
|
// contents (up to 128 bytes).
|
|
TruncatableString build_id = 2;
|
|
}
|
|
|
|
// Represents a string that might be shortened to a specified length.
|
|
message TruncatableString {
|
|
// The shortened string. For example, if the original string is 500
|
|
// bytes long and the limit of the string is 128 bytes, then
|
|
// `value` contains the first 128 bytes of the 500-byte string.
|
|
//
|
|
// Truncation always happens on a UTF8 character boundary. If there
|
|
// are multi-byte characters in the string, then the length of the
|
|
// shortened string might be less than the size limit.
|
|
string value = 1;
|
|
|
|
// The number of bytes removed from the original string. If this
|
|
// value is 0, then the string was not shortened.
|
|
int32 truncated_byte_count = 2;
|
|
}
|
|
|