parent
8cb3496eff
commit
f66e425a93
1 changed files with 216 additions and 0 deletions
@ -0,0 +1,216 @@ |
|||||||
|
// Copyright (c) 2015, 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.v1; |
||||||
|
|
||||||
|
import "google/api/annotations.proto"; |
||||||
|
import "google/protobuf/empty.proto"; |
||||||
|
import "google/protobuf/timestamp.proto"; |
||||||
|
|
||||||
|
option java_multiple_files = true; |
||||||
|
option java_outer_classname = "TraceProto"; |
||||||
|
option java_package = "com.google.devtools.cloudtrace.v1"; |
||||||
|
|
||||||
|
|
||||||
|
// This file describes an API for collecting and viewing traces and spans |
||||||
|
// within a trace. A Trace is a collection of spans corresponding to a single |
||||||
|
// operation or set of operations for an application. A span is an individual |
||||||
|
// timed event which forms a node of the trace tree. Spans for a single trace |
||||||
|
// may span multiple services. |
||||||
|
service TraceService { |
||||||
|
// Returns of a list of traces that match the specified filter conditions. |
||||||
|
rpc ListTraces(ListTracesRequest) returns (ListTracesResponse) { |
||||||
|
option (google.api.http) = { get: "/v1/projects/{project_id}/traces" }; |
||||||
|
} |
||||||
|
|
||||||
|
// Gets a single trace by its ID. |
||||||
|
rpc GetTrace(GetTraceRequest) returns (Trace) { |
||||||
|
option (google.api.http) = { get: "/v1/projects/{project_id}/traces/{trace_id}" }; |
||||||
|
} |
||||||
|
|
||||||
|
// Sends new traces to Cloud Trace or updates existing traces. If the ID of |
||||||
|
// a trace that you send matches that of an existing trace, any fields |
||||||
|
// in the existing trace and its spans are overwritten by the provided values, |
||||||
|
// and any new fields provided are merged with the existing trace data. If the |
||||||
|
// ID does not match, a new trace is created. |
||||||
|
rpc PatchTraces(PatchTracesRequest) returns (google.protobuf.Empty) { |
||||||
|
option (google.api.http) = { patch: "/v1/projects/{project_id}/traces" body: "traces" }; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// A trace describes how long it takes for an application to perform an |
||||||
|
// operation. It consists of a set of spans, each of which represent a single |
||||||
|
// timed event within the operation. |
||||||
|
message Trace { |
||||||
|
// Project ID of the Cloud project where the trace data is stored. |
||||||
|
string project_id = 1; |
||||||
|
|
||||||
|
// Globally unique identifier for the trace. This identifier is a 128-bit |
||||||
|
// numeric value formatted as a 32-byte hex string. |
||||||
|
string trace_id = 2; |
||||||
|
|
||||||
|
// Collection of spans in the trace. |
||||||
|
repeated TraceSpan spans = 3; |
||||||
|
} |
||||||
|
|
||||||
|
// List of new or updated traces. |
||||||
|
message Traces { |
||||||
|
// List of traces. |
||||||
|
repeated Trace traces = 1; |
||||||
|
} |
||||||
|
|
||||||
|
// A span represents a single timed event within a trace. Spans can be nested |
||||||
|
// and form a trace tree. Often, a trace contains a root span that describes the |
||||||
|
// end-to-end latency of an operation and, optionally, one or more subspans for |
||||||
|
// its suboperations. Spans do not need to be contiguous. There may be gaps |
||||||
|
// between spans in a trace. |
||||||
|
message TraceSpan { |
||||||
|
// Type of span. Can be used to specify additional relationships between spans |
||||||
|
// in addition to a parent/child relationship. |
||||||
|
enum SpanKind { |
||||||
|
// Unspecified. |
||||||
|
SPAN_KIND_UNSPECIFIED = 0; |
||||||
|
|
||||||
|
// Indicates that the span covers server-side handling of an RPC or other |
||||||
|
// remote network request. |
||||||
|
RPC_SERVER = 1; |
||||||
|
|
||||||
|
// Indicates that the span covers the client-side wrapper around an RPC or |
||||||
|
// other remote request. |
||||||
|
RPC_CLIENT = 2; |
||||||
|
} |
||||||
|
|
||||||
|
// Identifier for the span. This identifier must be unique within a trace. |
||||||
|
fixed64 span_id = 1; |
||||||
|
|
||||||
|
// Distinguishes between spans generated in a particular context. For example, |
||||||
|
// two spans with the same name may be distinguished using `RPC_CLIENT` |
||||||
|
// and `RPC_SERVER` to identify queueing latency associated with the span. |
||||||
|
SpanKind kind = 2; |
||||||
|
|
||||||
|
// Name of the trace. The trace name is sanitized and displayed in the |
||||||
|
// Cloud Trace tool in the Google Developers Console. The name may be a method |
||||||
|
// name or some other per-call site name. For the same executable and the same |
||||||
|
// call point, a best practice is to use a consistent name, which makes it |
||||||
|
// easier to correlate cross-trace spans. |
||||||
|
string name = 3; |
||||||
|
|
||||||
|
// Start time of the span in nanoseconds from the UNIX epoch. |
||||||
|
google.protobuf.Timestamp start_time = 4; |
||||||
|
|
||||||
|
// End time of the span in nanoseconds from the UNIX epoch. |
||||||
|
google.protobuf.Timestamp end_time = 5; |
||||||
|
|
||||||
|
// ID of the parent span, if any. Optional. |
||||||
|
fixed64 parent_span_id = 6; |
||||||
|
|
||||||
|
// Collection of labels associated with the span. |
||||||
|
map<string, string> labels = 7; |
||||||
|
} |
||||||
|
|
||||||
|
// The request message for the `ListTraces` method. All fields are required |
||||||
|
// unless specified. |
||||||
|
message ListTracesRequest { |
||||||
|
// Type of data returned for traces in the list. |
||||||
|
enum ViewType { |
||||||
|
// Default is `MINIMAL` if unspecified. |
||||||
|
VIEW_TYPE_UNSPECIFIED = 0; |
||||||
|
|
||||||
|
// Minimal view of the trace record that contains only the project |
||||||
|
// and trace IDs. |
||||||
|
MINIMAL = 1; |
||||||
|
|
||||||
|
// Root span view of the trace record that returns the root spans along |
||||||
|
// with the minimal trace data. |
||||||
|
ROOTSPAN = 2; |
||||||
|
|
||||||
|
// Complete view of the trace record that contains the actual trace data. |
||||||
|
// This is equivalent to calling the REST `get` or RPC `GetTrace` method |
||||||
|
// using the ID of each listed trace. |
||||||
|
COMPLETE = 3; |
||||||
|
} |
||||||
|
|
||||||
|
// ID of the Cloud project where the trace data is stored. |
||||||
|
string project_id = 1; |
||||||
|
|
||||||
|
// Type of data returned for traces in the list. Optional. Default is |
||||||
|
// `MINIMAL`. |
||||||
|
ViewType view = 2; |
||||||
|
|
||||||
|
// Maximum number of traces to return. If not specified or <= 0, the |
||||||
|
// implementation selects a reasonable value. The implementation may |
||||||
|
// return fewer traces than the requested page size. Optional. |
||||||
|
int32 page_size = 3; |
||||||
|
|
||||||
|
// Token identifying the page of results to return. If provided, use the |
||||||
|
// value of the `next_page_token` field from a previous request. Optional. |
||||||
|
string page_token = 4; |
||||||
|
|
||||||
|
// End of the time interval (inclusive) during which the trace data was |
||||||
|
// collected from the application. |
||||||
|
google.protobuf.Timestamp start_time = 5; |
||||||
|
|
||||||
|
// Start of the time interval (inclusive) during which the trace data was |
||||||
|
// collected from the application. |
||||||
|
google.protobuf.Timestamp end_time = 6; |
||||||
|
|
||||||
|
// An optional filter for the request. |
||||||
|
string filter = 7; |
||||||
|
|
||||||
|
// Field used to sort the returned traces. Optional. |
||||||
|
// Can be one of the following: |
||||||
|
// |
||||||
|
// * `trace_id` |
||||||
|
// * `name` (`name` field of root span in the trace) |
||||||
|
// * `duration` (difference between `end_time` and `start_time` fields of |
||||||
|
// the root span) |
||||||
|
// * `start` (`start_time` field of the root span) |
||||||
|
// |
||||||
|
// Descending order can be specified by appending `desc` to the sort field |
||||||
|
// (for example, `name desc`). |
||||||
|
// |
||||||
|
// Only one sort field is permitted. |
||||||
|
string order_by = 8; |
||||||
|
} |
||||||
|
|
||||||
|
// The response message for the `ListTraces` method. |
||||||
|
message ListTracesResponse { |
||||||
|
// List of trace records returned. |
||||||
|
repeated Trace traces = 1; |
||||||
|
|
||||||
|
// If defined, indicates that there are more traces that match the request |
||||||
|
// and that this value should be passed to the next request to continue |
||||||
|
// retrieving additional traces. |
||||||
|
string next_page_token = 2; |
||||||
|
} |
||||||
|
|
||||||
|
// The request message for the `GetTrace` method. |
||||||
|
message GetTraceRequest { |
||||||
|
// ID of the Cloud project where the trace data is stored. |
||||||
|
string project_id = 1; |
||||||
|
|
||||||
|
// ID of the trace to return. |
||||||
|
string trace_id = 2; |
||||||
|
} |
||||||
|
|
||||||
|
// The request message for the `PatchTraces` method. |
||||||
|
message PatchTracesRequest { |
||||||
|
// ID of the Cloud project where the trace data is stored. |
||||||
|
string project_id = 1; |
||||||
|
|
||||||
|
// The body of the message. |
||||||
|
Traces traces = 2; |
||||||
|
} |
Loading…
Reference in new issue