123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377 |
- // Copyright 2020 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.devtools.cloudtrace.v2;
- import "google/api/field_behavior.proto";
- import "google/api/resource.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";
- option ruby_package = "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 {
- option (google.api.resource) = {
- type: "cloudtrace.googleapis.com/Span"
- pattern: "projects/{project}/traces/{trace}/spans/{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, a signed 64-bit integer,
- // or the Boolean values `true` and `false`. For example:
- //
- // "/instance_id": { "string_value": { "value": "my-instance" } }
- // "/http/request_bytes": { "int_value": 300 }
- // "abc.com/myattribute": { "bool_value": false }
- 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;
- }
- // Type of span. Can be used to specify additional relationships between spans
- // in addition to a parent/child relationship.
- enum SpanKind {
- // Unspecified. Do NOT use as default.
- // Implementations MAY assume SpanKind.INTERNAL to be default.
- SPAN_KIND_UNSPECIFIED = 0;
- // Indicates that the span is used internally. Default value.
- INTERNAL = 1;
- // Indicates that the span covers server-side handling of an RPC or other
- // remote network request.
- SERVER = 2;
- // Indicates that the span covers the client-side wrapper around an RPC or
- // other remote request.
- CLIENT = 3;
- // Indicates that the span describes producer sending a message to a broker.
- // Unlike client and server, there is no direct critical path latency
- // relationship between producer and consumer spans (e.g. publishing a
- // message to a pubsub service).
- PRODUCER = 4;
- // Indicates that the span describes consumer receiving a message from a
- // broker. Unlike client and server, there is no direct critical path
- // latency relationship between producer and consumer spans (e.g. receiving
- // a message from a pubsub service subscription).
- CONSUMER = 5;
- }
- // Required. 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 [(google.api.field_behavior) = REQUIRED];
- // Required. The [SPAN_ID] portion of the span's resource name.
- string span_id = 2 [(google.api.field_behavior) = REQUIRED];
- // 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;
- // Required. A description of the span's operation (up to 128 bytes).
- // Stackdriver Trace displays the description in the
- // Google Cloud Platform Console.
- // 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 [(google.api.field_behavior) = REQUIRED];
- // Required. 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 [(google.api.field_behavior) = REQUIRED];
- // Required. 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 [(google.api.field_behavior) = REQUIRED];
- // 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;
- // Optional. The final status for this span.
- google.rpc.Status status = 11 [(google.api.field_behavior) = OPTIONAL];
- // 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 [(google.api.field_behavior) = OPTIONAL];
- // Optional. The 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 [(google.api.field_behavior) = OPTIONAL];
- // Optional. Distinguishes between spans generated in a particular context. For example,
- // two spans with the same name may be distinguished using `CLIENT` (caller)
- // and `SERVER` (callee) to identify an RPC call.
- SpanKind span_kind = 14 [(google.api.field_behavior) = OPTIONAL];
- }
- // 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;
- }
|