From 3aa566575fe8c5f8a84ac8a4972cbe17caba6581 Mon Sep 17 00:00:00 2001 From: Trask Stalnaker Date: Thu, 3 Mar 2022 05:38:54 -0800 Subject: [PATCH] Add table for well-known rpc.system values (#2377) --- semantic_conventions/trace/rpc.yaml | 16 +++++++++++++--- .../metrics/semantic_conventions/rpc.md | 10 +++++++++- specification/trace/semantic_conventions/rpc.md | 10 +++++++++- 3 files changed, 31 insertions(+), 5 deletions(-) diff --git a/semantic_conventions/trace/rpc.yaml b/semantic_conventions/trace/rpc.yaml index 6b37a1fa93..f87b5b29e5 100644 --- a/semantic_conventions/trace/rpc.yaml +++ b/semantic_conventions/trace/rpc.yaml @@ -5,10 +5,20 @@ groups: events: [rpc.message] attributes: - id: system - type: string required: always - brief: 'A string identifying the remoting system.' - examples: ["grpc", "java_rmi", "wcf"] + brief: 'A string identifying the remoting system. See below for a list of well-known identifiers.' + type: + allow_custom_values: true + members: + - id: grpc + value: 'grpc' + brief: 'gRPC' + - id: java_rmi + value: 'java_rmi' + brief: 'Java RMI' + - id: dotnet_wcf + value: 'dotnet_wcf' + brief: '.NET WCF' - id: service type: string required: diff --git a/specification/metrics/semantic_conventions/rpc.md b/specification/metrics/semantic_conventions/rpc.md index 12c6d57b93..9c5efe3e8c 100644 --- a/specification/metrics/semantic_conventions/rpc.md +++ b/specification/metrics/semantic_conventions/rpc.md @@ -60,7 +60,7 @@ or not they should be on the server, client or both. | Attribute | Type | Description | Examples | Required | |---|---|---|---|---| -| [`rpc.system`](../../trace/semantic_conventions/rpc.md) | string | A string identifying the remoting system. | `grpc`; `java_rmi`; `wcf` | Yes | +| [`rpc.system`](../../trace/semantic_conventions/rpc.md) | string | A string identifying the remoting system. See below for a list of well-known identifiers. | `grpc` | Yes | | [`rpc.service`](../../trace/semantic_conventions/rpc.md) | string | The full (logical) name of the service being called, including its package name, if applicable. [1] | `myservice.EchoService` | No, but recommended | | [`rpc.method`](../../trace/semantic_conventions/rpc.md) | string | The name of the (logical) method being called, must be equal to the $method part in the span name. [2] | `exampleMethod` | No, but recommended | | [`net.peer.ip`](../../trace/semantic_conventions/span-general.md) | string | Remote address of the peer (dotted decimal for IPv4 or [RFC5952](https://tools.ietf.org/html/rfc5952) for IPv6) | `127.0.0.1` | See below | @@ -76,6 +76,14 @@ or not they should be on the server, client or both. * [`net.peer.ip`](../../trace/semantic_conventions/span-general.md) * [`net.peer.name`](../../trace/semantic_conventions/span-general.md) + +`rpc.system` MUST be one of the following or, if none of the listed values apply, a custom value: + +| Value | Description | +|---|---| +| `grpc` | gRPC | +| `java_rmi` | Java RMI | +| `dotnet_wcf` | .NET WCF | To avoid high cardinality, implementations should prefer the most stable of `net.peer.name` or diff --git a/specification/trace/semantic_conventions/rpc.md b/specification/trace/semantic_conventions/rpc.md index 41853bbdba..67f835d68b 100644 --- a/specification/trace/semantic_conventions/rpc.md +++ b/specification/trace/semantic_conventions/rpc.md @@ -56,7 +56,7 @@ Examples of span names: | Attribute | Type | Description | Examples | Required | |---|---|---|---|---| -| `rpc.system` | string | A string identifying the remoting system. | `grpc`; `java_rmi`; `wcf` | Yes | +| `rpc.system` | string | A string identifying the remoting system. See below for a list of well-known identifiers. | `grpc` | Yes | | `rpc.service` | string | The full (logical) name of the service being called, including its package name, if applicable. [1] | `myservice.EchoService` | No, but recommended | | `rpc.method` | string | The name of the (logical) method being called, must be equal to the $method part in the span name. [2] | `exampleMethod` | No, but recommended | | [`net.peer.ip`](span-general.md) | string | Remote address of the peer (dotted decimal for IPv4 or [RFC5952](https://tools.ietf.org/html/rfc5952) for IPv6) | `127.0.0.1` | See below | @@ -72,6 +72,14 @@ Examples of span names: * [`net.peer.ip`](span-general.md) * [`net.peer.name`](span-general.md) + +`rpc.system` MUST be one of the following or, if none of the listed values apply, a custom value: + +| Value | Description | +|---|---| +| `grpc` | gRPC | +| `java_rmi` | Java RMI | +| `dotnet_wcf` | .NET WCF | For client-side spans `net.peer.port` is required if the connection is IP-based and the port is available (it describes the server port they are connecting to).