Separation of attribute definitions from attribute usages: HTTP (#208)
Signed-off-by: Alexander Wert <alexander.wert@elastic.co> Co-authored-by: Joao Grassi <joao@joaograssi.com> Co-authored-by: Armin Ruech <armin.ruech@dynatrace.com>
This commit is contained in:
parent
559bf8bd66
commit
4040095eda
|
|
@ -0,0 +1,32 @@
|
|||
<!--- Hugo front matter used to generate the website version of this page:
|
||||
linkTitle: Registry
|
||||
weight: -2
|
||||
--->
|
||||
|
||||
# Attributes Registry
|
||||
|
||||
The attributes registry is the place where attributes are defined. An attribute definition covers the following properties of an attribute:
|
||||
|
||||
- the `id` (the fully qualified name) of the attribute
|
||||
- the `type` of the attribute
|
||||
- a `brief` description of the attribute and optionally a longer `note`
|
||||
- example values
|
||||
|
||||
Attributes defined in the registry can be used in different semantic conventions. Attributes should be included in this registry before they are used in semantic conventions. Semantic conventions may override all the properties of an attribute except for the `id` and `type` in case it's required for a particular context. In addition, semantic conventions specify the requirement level of an attribute in the corresponding context.
|
||||
|
||||
A definition of an attribute in the registry does not necessarily imply that the attribute is used in any of the semantic conventions.
|
||||
|
||||
If applicable, application developers are encouraged to use existing attributes from this registry. See also [these recommendations][developers recommendations] regarding attribute selection and attribute naming for custom use cases.
|
||||
|
||||
All registered attributes are listed by namespace in this registry.
|
||||
|
||||
> **Warning**
|
||||
> The following registry overview is a work in progress.
|
||||
>
|
||||
> Further attribute namespaces are currently being migrated and will appear in this registry soon.
|
||||
|
||||
Currently, the following namespaces exist:
|
||||
|
||||
* [HTTP](http.md)
|
||||
|
||||
[developers recommendations]: https://github.com/open-telemetry/opentelemetry-specification/blob/v1.22.0/specification/common/attribute-naming.md#recommendations-for-application-developers
|
||||
|
|
@ -0,0 +1,77 @@
|
|||
<!--- Hugo front matter used to generate the website version of this page:
|
||||
--->
|
||||
|
||||
# HTTP
|
||||
|
||||
## HTTP Attributes
|
||||
|
||||
<!-- semconv registry.http(omit_requirement_level) -->
|
||||
| Attribute | Type | Description | Examples |
|
||||
|---|---|---|---|
|
||||
| `http.request.body.size` | int | The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` |
|
||||
| `http.request.header.<key>` | string[] | HTTP request headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [1] | `http.request.header.content_type=["application/json"]`; `http.request.header.x_forwarded_for=["1.2.3.4", "1.2.3.5"]` |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` |
|
||||
| `http.request.method_original` | string | Original HTTP method sent by the client in the request line. | `GeT`; `ACL`; `foo` |
|
||||
| `http.resend_count` | int | The ordinal number of request resending attempt (for any reason, including redirects). [3] | `3` |
|
||||
| `http.response.body.size` | int | The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` |
|
||||
| `http.response.header.<key>` | string[] | HTTP response headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [4] | `http.response.header.content_type=["application/json"]`; `http.response.header.my_custom_header=["abc", "def"]` |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` |
|
||||
| `http.route` | string | The matched route (path template in the format used by the respective server framework). See note below [5] | `/users/:userID?`; `{controller}/{action}/{id?}` |
|
||||
|
||||
**[1]:** Instrumentations SHOULD require an explicit configuration of which headers are to be captured. Including all request headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
The `User-Agent` header is already captured in the `user_agent.original` attribute. Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
The attribute value MUST consist of either multiple header values as an array of strings or a single-item array containing a possibly comma-concatenated string, depending on the way the HTTP library provides access to headers.
|
||||
|
||||
**[2]:** HTTP request method value SHOULD be "known" to the instrumentation.
|
||||
By default, this convention defines "known" methods as the ones listed in [RFC9110](https://www.rfc-editor.org/rfc/rfc9110.html#name-methods)
|
||||
and the PATCH method defined in [RFC5789](https://www.rfc-editor.org/rfc/rfc5789.html).
|
||||
|
||||
If the HTTP request method is not known to instrumentation, it MUST set the `http.request.method` attribute to `_OTHER`.
|
||||
|
||||
If the HTTP instrumentation could end up converting valid HTTP request methods to `_OTHER`, then it MUST provide a way to override
|
||||
the list of known HTTP methods. If this override is done via environment variable, then the environment variable MUST be named
|
||||
OTEL_INSTRUMENTATION_HTTP_KNOWN_METHODS and support a comma-separated list of case-sensitive known HTTP methods
|
||||
(this list MUST be a full override of the default known method, it is not a list of known methods in addition to the defaults).
|
||||
|
||||
HTTP method names are case-sensitive and `http.request.method` attribute value MUST match a known HTTP method name exactly.
|
||||
Instrumentations for specific web frameworks that consider HTTP methods to be case insensitive, SHOULD populate a canonical equivalent.
|
||||
Tracing instrumentations that do so, MUST also set `http.request.method_original` to the original value.
|
||||
|
||||
**[3]:** The resend count SHOULD be updated each time an HTTP request gets resent by the client, regardless of what was the cause of the resending (e.g. redirection, authorization failure, 503 Server Unavailable, network issues, or any other).
|
||||
|
||||
**[4]:** Instrumentations SHOULD require an explicit configuration of which headers are to be captured. Including all response headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
The attribute value MUST consist of either multiple header values as an array of strings or a single-item array containing a possibly comma-concatenated string, depending on the way the HTTP library provides access to headers.
|
||||
|
||||
**[5]:** MUST NOT be populated when this is not supported by the HTTP server framework as the route attribute should have low-cardinality and the URI path can NOT substitute it.
|
||||
SHOULD include the [application root](/docs/http/http-spans.md#http-server-definitions) if there is one.
|
||||
|
||||
`http.request.method` has the following list of well-known values. If one of them applies, then the respective value MUST be used, otherwise a custom value MAY be used.
|
||||
|
||||
| Value | Description |
|
||||
|---|---|
|
||||
| `CONNECT` | CONNECT method. |
|
||||
| `DELETE` | DELETE method. |
|
||||
| `GET` | GET method. |
|
||||
| `HEAD` | HEAD method. |
|
||||
| `OPTIONS` | OPTIONS method. |
|
||||
| `PATCH` | PATCH method. |
|
||||
| `POST` | POST method. |
|
||||
| `PUT` | PUT method. |
|
||||
| `TRACE` | TRACE method. |
|
||||
| `_OTHER` | Any HTTP method that the instrumentation has no prior knowledge of. |
|
||||
<!-- endsemconv -->
|
||||
|
||||
## Deprecated HTTP Attributes
|
||||
|
||||
<!-- semconv attributes.http.deprecated(omit_requirement_level) -->
|
||||
| Attribute | Type | Description | Examples |
|
||||
|---|---|---|---|
|
||||
| `http.method` | string | Deprecated, use `http.request.method` instead. | `GET`; `POST`; `HEAD` |
|
||||
| `http.request_content_length` | int | Deprecated, use `http.request.body.size` instead. | `3495` |
|
||||
| `http.response_content_length` | int | Deprecated, use `http.response.body.size` instead. | `3495` |
|
||||
| `http.scheme` | string | Deprecated, use `url.scheme` instead. | `http`; `https` |
|
||||
| `http.status_code` | int | Deprecated, use `http.response.status_code` instead. | `200` |
|
||||
| `http.target` | string | Deprecated, use `url.path` and `url.query` instead. | `/search?q=OpenTelemetry#SemConv` |
|
||||
| `http.url` | string | Deprecated, use `url.full` instead. | `https://www.foo.bar/search?q=OpenTelemetry#SemConv` |
|
||||
<!-- endsemconv -->
|
||||
|
|
@ -31,7 +31,7 @@ If the endpoint id is not available, the span name SHOULD be the `http.request.m
|
|||
| `db.elasticsearch.path_parts.<key>` | string | A dynamic value in the url path. [3] | `db.elasticsearch.path_parts.index=test-index`; `db.elasticsearch.path_parts.doc_id=123` | Conditionally Required: when the url has dynamic values |
|
||||
| [`db.operation`](database-spans.md) | string | The endpoint identifier for the request. [4] | `search`; `ml.close_job`; `cat.aliases` | Required |
|
||||
| [`db.statement`](database-spans.md) | string | The request body for a [search-type query](https://www.elastic.co/guide/en/elasticsearch/reference/current/search.html), as a json string. | `"{\"query\":{\"term\":{\"user.id\":\"kimchy\"}}}"` | Recommended: [5] |
|
||||
| `http.request.method` | string | HTTP request method. [6] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [6] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the database host. [7] | `example.com` | Conditionally Required: See alternative attributes below. |
|
||||
| [`server.port`](../general/attributes.md) | int | Server port number [8] | `80`; `8080`; `443` | Conditionally Required: [9] |
|
||||
| [`url.full`](../url/url.md) | string | Absolute URL describing a network resource according to [RFC3986](https://www.rfc-editor.org/rfc/rfc3986) [10] | `https://localhost:9200/index/_search?q=user.id:kimchy` | Required |
|
||||
|
|
|
|||
|
|
@ -77,9 +77,9 @@ of `[ 0.005, 0.01, 0.025, 0.05, 0.075, 0.1, 0.25, 0.5, 0.75, 1, 2.5, 5, 7.5, 10
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| `http.route` | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.route`](../attributes-registry/http.md) | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [4] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [5] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the local HTTP server that received the request. [6] | `example.com` | Opt-In |
|
||||
|
|
@ -178,7 +178,7 @@ This metric is optional.
|
|||
<!-- semconv metric.http.server.active_requests(full) -->
|
||||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `http.request.method` | string | HTTP request method. [1] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [1] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the local HTTP server that received the request. [2] | `example.com` | Opt-In |
|
||||
| [`server.port`](../general/attributes.md) | int | Port of the local HTTP server that received the request. [3] | `80`; `8080`; `443` | Opt-In |
|
||||
| [`url.scheme`](../url/url.md) | string | The [URI scheme](https://www.rfc-editor.org/rfc/rfc3986#section-3.1) component identifying the used protocol. | `http`; `https` | Required |
|
||||
|
|
@ -249,9 +249,9 @@ This metric is optional.
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| `http.route` | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.route`](../attributes-registry/http.md) | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [4] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [5] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the local HTTP server that received the request. [6] | `example.com` | Opt-In |
|
||||
|
|
@ -353,9 +353,9 @@ This metric is optional.
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| `http.route` | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.route`](../attributes-registry/http.md) | string | The matched route (path template in the format used by the respective server framework). See note below [3] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [4] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [5] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the local HTTP server that received the request. [6] | `example.com` | Opt-In |
|
||||
|
|
@ -463,8 +463,8 @@ of `[ 0.005, 0.01, 0.025, 0.05, 0.075, 0.1, 0.25, 0.5, 0.75, 1, 2.5, 5, 7.5, 10
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [3] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [4] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Host identifier of the ["URI origin"](https://www.rfc-editor.org/rfc/rfc9110.html#name-uri-origin) HTTP request is sent to. [5] | `example.com` | Required |
|
||||
|
|
@ -558,8 +558,8 @@ This metric is optional.
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [3] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [4] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Host identifier of the ["URI origin"](https://www.rfc-editor.org/rfc/rfc9110.html#name-uri-origin) HTTP request is sent to. [5] | `example.com` | Required |
|
||||
|
|
@ -653,8 +653,8 @@ This metric is optional.
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.method` | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [2] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [3] | `amqp`; `http`; `mqtt` | Recommended |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [4] | `3.1.1` | Recommended |
|
||||
| [`server.address`](../general/attributes.md) | string | Host identifier of the ["URI origin"](https://www.rfc-editor.org/rfc/rfc9110.html#name-uri-origin) HTTP request is sent to. [5] | `example.com` | Required |
|
||||
|
|
|
|||
|
|
@ -116,13 +116,13 @@ sections below.
|
|||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `error.type` | string | Describes a class of error the operation ended with. [1] | `timeout`; `name_resolution_error`; `500` | Conditionally Required: If request has ended with an error. |
|
||||
| `http.request.body.size` | int | The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` | Recommended |
|
||||
| `http.request.header.<key>` | string[] | HTTP request headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [2] | `http.request.header.content_type=["application/json"]`; `http.request.header.x_forwarded_for=["1.2.3.4", "1.2.3.5"]` | Opt-In |
|
||||
| `http.request.method` | string | HTTP request method. [3] | `GET`; `POST`; `HEAD` | Required |
|
||||
| `http.request.method_original` | string | Original HTTP method sent by the client in the request line. | `GeT`; `ACL`; `foo` | Conditionally Required: [4] |
|
||||
| `http.response.body.size` | int | The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` | Recommended |
|
||||
| `http.response.header.<key>` | string[] | HTTP response headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [5] | `http.response.header.content_type=["application/json"]`; `http.response.header.my_custom_header=["abc", "def"]` | Opt-In |
|
||||
| `http.response.status_code` | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`http.request.body.size`](../attributes-registry/http.md) | int | The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` | Recommended |
|
||||
| [`http.request.header.<key>`](../attributes-registry/http.md) | string[] | HTTP request headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [2] | `http.request.header.content_type=["application/json"]`; `http.request.header.x_forwarded_for=["1.2.3.4", "1.2.3.5"]` | Opt-In |
|
||||
| [`http.request.method`](../attributes-registry/http.md) | string | HTTP request method. [3] | `GET`; `POST`; `HEAD` | Required |
|
||||
| [`http.request.method_original`](../attributes-registry/http.md) | string | Original HTTP method sent by the client in the request line. | `GeT`; `ACL`; `foo` | Conditionally Required: [4] |
|
||||
| [`http.response.body.size`](../attributes-registry/http.md) | int | The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size. | `3495` | Recommended |
|
||||
| [`http.response.header.<key>`](../attributes-registry/http.md) | string[] | HTTP response headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values. [5] | `http.response.header.content_type=["application/json"]`; `http.response.header.my_custom_header=["abc", "def"]` | Opt-In |
|
||||
| [`http.response.status_code`](../attributes-registry/http.md) | int | [HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6). | `200` | Conditionally Required: If and only if one was received/sent. |
|
||||
| [`network.protocol.name`](../general/attributes.md) | string | [OSI application layer](https://osi-model.com/application-layer/) or non-OSI equivalent. [6] | `http`; `spdy` | Recommended: if not default (`http`). |
|
||||
| [`network.protocol.version`](../general/attributes.md) | string | Version of the protocol specified in `network.protocol.name`. [7] | `1.0`; `1.1`; `2`; `3` | Recommended |
|
||||
| [`network.transport`](../general/attributes.md) | string | [OSI transport layer](https://osi-model.com/transport-layer/) or [inter-process communication method](https://en.wikipedia.org/wiki/Inter-process_communication). [8] | `tcp`; `udp` | Conditionally Required: [9] |
|
||||
|
|
@ -186,7 +186,7 @@ different processes could be listening on TCP port 12345 and UDP port 12345.
|
|||
|
||||
Following attributes MUST be provided **at span creation time** (when provided at all), so they can be considered for sampling decisions:
|
||||
|
||||
* `http.request.method`
|
||||
* [`http.request.method`](../attributes-registry/http.md)
|
||||
|
||||
`error.type` has the following list of well-known values. If one of them applies, then the respective value MUST be used, otherwise a custom value MAY be used.
|
||||
|
||||
|
|
@ -243,7 +243,7 @@ For an HTTP client span, `SpanKind` MUST be `Client`.
|
|||
<!-- semconv trace.http.client(full) -->
|
||||
| Attribute | Type | Description | Examples | Requirement Level |
|
||||
|---|---|---|---|---|
|
||||
| `http.resend_count` | int | The ordinal number of request resending attempt (for any reason, including redirects). [1] | `3` | Recommended: if and only if request was retried. |
|
||||
| [`http.resend_count`](../attributes-registry/http.md) | int | The ordinal number of request resending attempt (for any reason, including redirects). [1] | `3` | Recommended: if and only if request was retried. |
|
||||
| [`server.address`](../general/attributes.md) | string | Host identifier of the ["URI origin"](https://www.rfc-editor.org/rfc/rfc9110.html#name-uri-origin) HTTP request is sent to. [2] | `example.com` | Required |
|
||||
| [`server.port`](../general/attributes.md) | int | Port identifier of the ["URI origin"](https://www.rfc-editor.org/rfc/rfc9110.html#name-uri-origin) HTTP request is sent to. [3] | `80`; `8080`; `443` | Conditionally Required: [4] |
|
||||
| [`server.socket.address`](../general/attributes.md) | string | Server address of the socket connection - IP address or Unix domain socket name. [5] | `10.5.3.2` | Recommended: If different than `server.address`. |
|
||||
|
|
@ -379,7 +379,7 @@ For an HTTP server span, `SpanKind` MUST be `Server`.
|
|||
| [`client.port`](../general/attributes.md) | int | The port of the original client behind all proxies, if known (e.g. from [Forwarded](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Forwarded) or a similar header). Otherwise, the immediate client peer port. [2] | `65123` | Recommended |
|
||||
| [`client.socket.address`](../general/attributes.md) | string | Client address of the socket connection - IP address or Unix domain socket name. [3] | `/tmp/my.sock`; `127.0.0.1` | Recommended: If different than `client.address`. |
|
||||
| [`client.socket.port`](../general/attributes.md) | int | Client port number of the socket connection. [4] | `35555` | Recommended: If different than `client.port`. |
|
||||
| `http.route` | string | The matched route (path template in the format used by the respective server framework). See note below [5] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`http.route`](../attributes-registry/http.md) | string | The matched route (path template in the format used by the respective server framework). See note below [5] | `/users/:userID?`; `{controller}/{action}/{id?}` | Conditionally Required: If and only if it's available |
|
||||
| [`server.address`](../general/attributes.md) | string | Name of the local HTTP server that received the request. [6] | `example.com` | Recommended |
|
||||
| [`server.port`](../general/attributes.md) | int | Port of the local HTTP server that received the request. [7] | `80`; `8080`; `443` | Recommended: [8] |
|
||||
| [`server.socket.address`](../general/attributes.md) | string | Local socket address. Useful in case of a multi-IP host. [9] | `10.5.3.2` | Opt-In |
|
||||
|
|
|
|||
|
|
@ -2,66 +2,12 @@ groups:
|
|||
- id: attributes.http.common
|
||||
type: attribute_group
|
||||
brief: "Describes HTTP attributes."
|
||||
prefix: http
|
||||
attributes:
|
||||
- id: request.method
|
||||
type:
|
||||
allow_custom_values: true
|
||||
members:
|
||||
- id: connect
|
||||
value: "CONNECT"
|
||||
brief: 'CONNECT method.'
|
||||
- id: delete
|
||||
value: "DELETE"
|
||||
brief: 'DELETE method.'
|
||||
- id: get
|
||||
value: "GET"
|
||||
brief: 'GET method.'
|
||||
- id: head
|
||||
value: "HEAD"
|
||||
brief: 'HEAD method.'
|
||||
- id: options
|
||||
value: "OPTIONS"
|
||||
brief: 'OPTIONS method.'
|
||||
- id: patch
|
||||
value: "PATCH"
|
||||
brief: 'PATCH method.'
|
||||
- id: post
|
||||
value: "POST"
|
||||
brief: 'POST method.'
|
||||
- id: put
|
||||
value: "PUT"
|
||||
brief: 'PUT method.'
|
||||
- id: trace
|
||||
value: "TRACE"
|
||||
brief: 'TRACE method.'
|
||||
- id: other
|
||||
value: "_OTHER"
|
||||
brief: 'Any HTTP method that the instrumentation has no prior knowledge of.'
|
||||
- ref: http.request.method
|
||||
requirement_level: required
|
||||
brief: 'HTTP request method.'
|
||||
examples: ["GET", "POST", "HEAD"]
|
||||
note: |
|
||||
HTTP request method value SHOULD be "known" to the instrumentation.
|
||||
By default, this convention defines "known" methods as the ones listed in [RFC9110](https://www.rfc-editor.org/rfc/rfc9110.html#name-methods)
|
||||
and the PATCH method defined in [RFC5789](https://www.rfc-editor.org/rfc/rfc5789.html).
|
||||
|
||||
If the HTTP request method is not known to instrumentation, it MUST set the `http.request.method` attribute to `_OTHER`.
|
||||
|
||||
If the HTTP instrumentation could end up converting valid HTTP request methods to `_OTHER`, then it MUST provide a way to override
|
||||
the list of known HTTP methods. If this override is done via environment variable, then the environment variable MUST be named
|
||||
OTEL_INSTRUMENTATION_HTTP_KNOWN_METHODS and support a comma-separated list of case-sensitive known HTTP methods
|
||||
(this list MUST be a full override of the default known method, it is not a list of known methods in addition to the defaults).
|
||||
|
||||
HTTP method names are case-sensitive and `http.request.method` attribute value MUST match a known HTTP method name exactly.
|
||||
Instrumentations for specific web frameworks that consider HTTP methods to be case insensitive, SHOULD populate a canonical equivalent.
|
||||
Tracing instrumentations that do so, MUST also set `http.request.method_original` to the original value.
|
||||
- id: response.status_code
|
||||
type: int
|
||||
- ref: http.response.status_code
|
||||
requirement_level:
|
||||
conditionally_required: If and only if one was received/sent.
|
||||
brief: '[HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6).'
|
||||
examples: [200]
|
||||
- ref: error.type
|
||||
requirement_level:
|
||||
conditionally_required: If request has ended with an error.
|
||||
|
|
@ -90,7 +36,6 @@ groups:
|
|||
examples: ['1.0', '1.1', '2', '3']
|
||||
|
||||
- id: attributes.http.client
|
||||
prefix: http
|
||||
type: attribute_group
|
||||
brief: 'HTTP Client attributes'
|
||||
attributes:
|
||||
|
|
@ -116,21 +61,12 @@ groups:
|
|||
URI port identifier, otherwise it MUST match `Host` header port identifier.
|
||||
|
||||
- id: attributes.http.server
|
||||
prefix: http
|
||||
type: attribute_group
|
||||
brief: 'HTTP Server attributes'
|
||||
attributes:
|
||||
- id: route
|
||||
type: string
|
||||
- ref: http.route
|
||||
requirement_level:
|
||||
conditionally_required: If and only if it's available
|
||||
brief: >
|
||||
The matched route (path template in the format used by the respective server framework). See note below
|
||||
examples: ['/users/:userID?', '{controller}/{action}/{id?}']
|
||||
note: >
|
||||
MUST NOT be populated when this is not supported by the HTTP server framework as the route attribute should have low-cardinality and the URI path can NOT substitute it.
|
||||
|
||||
SHOULD include the [application root](/docs/http/http-spans.md#http-server-definitions) if there is one.
|
||||
- ref: server.address
|
||||
brief: >
|
||||
Name of the local HTTP server that received the request.
|
||||
|
|
|
|||
|
|
@ -52,7 +52,10 @@ groups:
|
|||
|
||||
If the request has completed successfully, instrumentations SHOULD NOT set `error.type`.
|
||||
- ref: http.request.method
|
||||
requirement_level: required
|
||||
- ref: http.response.status_code
|
||||
requirement_level:
|
||||
conditionally_required: If and only if one was received/sent.
|
||||
- ref: network.protocol.name
|
||||
- ref: network.protocol.version
|
||||
|
||||
|
|
@ -63,7 +66,10 @@ groups:
|
|||
attributes:
|
||||
# todo (lmolkova) build tools don't populate grandparent attributes
|
||||
- ref: http.request.method
|
||||
requirement_level: required
|
||||
- ref: http.response.status_code
|
||||
requirement_level:
|
||||
conditionally_required: If and only if one was received/sent.
|
||||
- ref: network.protocol.name
|
||||
- ref: network.protocol.version
|
||||
- ref: error.type
|
||||
|
|
@ -105,6 +111,7 @@ groups:
|
|||
unit: "{request}"
|
||||
attributes:
|
||||
- ref: http.request.method
|
||||
requirement_level: required
|
||||
- ref: url.scheme
|
||||
requirement_level: required
|
||||
examples: ["http", "https"]
|
||||
|
|
|
|||
|
|
@ -0,0 +1,126 @@
|
|||
groups:
|
||||
- id: registry.http
|
||||
prefix: http
|
||||
type: attribute_group
|
||||
brief: 'This document defines semantic convention attributes in the HTTP namespace.'
|
||||
attributes:
|
||||
- id: request.body.size
|
||||
type: int
|
||||
brief: >
|
||||
The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and
|
||||
is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length)
|
||||
header. For requests using transport encoding, this should be the compressed size.
|
||||
examples: 3495
|
||||
- id: request.header
|
||||
type: template[string[]]
|
||||
brief: >
|
||||
HTTP request headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values.
|
||||
note: >
|
||||
Instrumentations SHOULD require an explicit configuration of which headers are to be captured.
|
||||
Including all request headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
|
||||
The `User-Agent` header is already captured in the `user_agent.original` attribute.
|
||||
Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
|
||||
The attribute value MUST consist of either multiple header values as an array of strings
|
||||
or a single-item array containing a possibly comma-concatenated string, depending on the way
|
||||
the HTTP library provides access to headers.
|
||||
examples: ['http.request.header.content_type=["application/json"]', 'http.request.header.x_forwarded_for=["1.2.3.4", "1.2.3.5"]']
|
||||
- id: request.method
|
||||
type:
|
||||
allow_custom_values: true
|
||||
members:
|
||||
- id: connect
|
||||
value: "CONNECT"
|
||||
brief: 'CONNECT method.'
|
||||
- id: delete
|
||||
value: "DELETE"
|
||||
brief: 'DELETE method.'
|
||||
- id: get
|
||||
value: "GET"
|
||||
brief: 'GET method.'
|
||||
- id: head
|
||||
value: "HEAD"
|
||||
brief: 'HEAD method.'
|
||||
- id: options
|
||||
value: "OPTIONS"
|
||||
brief: 'OPTIONS method.'
|
||||
- id: patch
|
||||
value: "PATCH"
|
||||
brief: 'PATCH method.'
|
||||
- id: post
|
||||
value: "POST"
|
||||
brief: 'POST method.'
|
||||
- id: put
|
||||
value: "PUT"
|
||||
brief: 'PUT method.'
|
||||
- id: trace
|
||||
value: "TRACE"
|
||||
brief: 'TRACE method.'
|
||||
- id: other
|
||||
value: "_OTHER"
|
||||
brief: 'Any HTTP method that the instrumentation has no prior knowledge of.'
|
||||
brief: 'HTTP request method.'
|
||||
examples: ["GET", "POST", "HEAD"]
|
||||
note: |
|
||||
HTTP request method value SHOULD be "known" to the instrumentation.
|
||||
By default, this convention defines "known" methods as the ones listed in [RFC9110](https://www.rfc-editor.org/rfc/rfc9110.html#name-methods)
|
||||
and the PATCH method defined in [RFC5789](https://www.rfc-editor.org/rfc/rfc5789.html).
|
||||
|
||||
If the HTTP request method is not known to instrumentation, it MUST set the `http.request.method` attribute to `_OTHER`.
|
||||
|
||||
If the HTTP instrumentation could end up converting valid HTTP request methods to `_OTHER`, then it MUST provide a way to override
|
||||
the list of known HTTP methods. If this override is done via environment variable, then the environment variable MUST be named
|
||||
OTEL_INSTRUMENTATION_HTTP_KNOWN_METHODS and support a comma-separated list of case-sensitive known HTTP methods
|
||||
(this list MUST be a full override of the default known method, it is not a list of known methods in addition to the defaults).
|
||||
|
||||
HTTP method names are case-sensitive and `http.request.method` attribute value MUST match a known HTTP method name exactly.
|
||||
Instrumentations for specific web frameworks that consider HTTP methods to be case insensitive, SHOULD populate a canonical equivalent.
|
||||
Tracing instrumentations that do so, MUST also set `http.request.method_original` to the original value.
|
||||
- id: request.method_original
|
||||
type: string
|
||||
brief: Original HTTP method sent by the client in the request line.
|
||||
examples: ["GeT", "ACL", "foo"]
|
||||
- id: resend_count
|
||||
type: int
|
||||
brief: >
|
||||
The ordinal number of request resending attempt (for any reason, including redirects).
|
||||
note: >
|
||||
The resend count SHOULD be updated each time an HTTP request gets resent by the client, regardless of what
|
||||
was the cause of the resending (e.g. redirection, authorization failure, 503 Server Unavailable, network issues,
|
||||
or any other).
|
||||
examples: 3
|
||||
- id: response.body.size
|
||||
type: int
|
||||
brief: >
|
||||
The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and
|
||||
is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length)
|
||||
header. For requests using transport encoding, this should be the compressed size.
|
||||
examples: 3495
|
||||
- id: response.header
|
||||
type: template[string[]]
|
||||
brief: >
|
||||
HTTP response headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values.
|
||||
note: >
|
||||
Instrumentations SHOULD require an explicit configuration of which headers are to be captured.
|
||||
Including all response headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
|
||||
Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
|
||||
The attribute value MUST consist of either multiple header values as an array of strings
|
||||
or a single-item array containing a possibly comma-concatenated string, depending on the way
|
||||
the HTTP library provides access to headers.
|
||||
examples: ['http.response.header.content_type=["application/json"]', 'http.response.header.my_custom_header=["abc", "def"]']
|
||||
- id: response.status_code
|
||||
type: int
|
||||
brief: '[HTTP response status code](https://tools.ietf.org/html/rfc7231#section-6).'
|
||||
examples: [200]
|
||||
- id: route
|
||||
type: string
|
||||
brief: >
|
||||
The matched route (path template in the format used by the respective server framework). See note below
|
||||
examples: ['/users/:userID?', '{controller}/{action}/{id?}']
|
||||
note: >
|
||||
MUST NOT be populated when this is not supported by the HTTP server framework as the route attribute should have low-cardinality and the URI path can NOT substitute it.
|
||||
|
||||
SHOULD include the [application root](/docs/http/http-spans.md#http-server-definitions) if there is one.
|
||||
|
|
@ -1,6 +1,5 @@
|
|||
groups:
|
||||
- id: trace.http.common
|
||||
prefix: http
|
||||
extends: attributes.http.common
|
||||
type: attribute_group
|
||||
brief: 'This document defines semantic conventions for HTTP client and server Spans.'
|
||||
|
|
@ -8,59 +7,18 @@ groups:
|
|||
These conventions can be used for http and https schemes
|
||||
and various HTTP versions like 1.1, 2 and SPDY.
|
||||
attributes:
|
||||
- id: request.method_original
|
||||
type: string
|
||||
- ref: http.request.method_original
|
||||
requirement_level:
|
||||
conditionally_required: If and only if it's different than `http.request.method`.
|
||||
brief: Original HTTP method sent by the client in the request line.
|
||||
examples: ["GeT", "ACL", "foo"]
|
||||
- id: request.body.size
|
||||
type: int
|
||||
brief: >
|
||||
The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and
|
||||
is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length)
|
||||
header. For requests using transport encoding, this should be the compressed size.
|
||||
examples: 3495
|
||||
- id: response.body.size
|
||||
type: int
|
||||
brief: >
|
||||
The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and
|
||||
is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length)
|
||||
header. For requests using transport encoding, this should be the compressed size.
|
||||
examples: 3495
|
||||
- id: request.header
|
||||
type: template[string[]]
|
||||
- ref: http.request.body.size
|
||||
- ref: http.request.header
|
||||
requirement_level: opt_in
|
||||
brief: >
|
||||
HTTP request headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values.
|
||||
note: >
|
||||
Instrumentations SHOULD require an explicit configuration of which headers are to be captured.
|
||||
Including all request headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
|
||||
The `User-Agent` header is already captured in the `user_agent.original` attribute.
|
||||
Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
|
||||
The attribute value MUST consist of either multiple header values as an array of strings
|
||||
or a single-item array containing a possibly comma-concatenated string, depending on the way
|
||||
the HTTP library provides access to headers.
|
||||
examples: ['http.request.header.content_type=["application/json"]', 'http.request.header.x_forwarded_for=["1.2.3.4", "1.2.3.5"]']
|
||||
- id: response.header
|
||||
type: template[string[]]
|
||||
- ref: http.response.body.size
|
||||
- ref: http.response.header
|
||||
requirement_level: opt_in
|
||||
brief: >
|
||||
HTTP response headers, `<key>` being the normalized HTTP Header name (lowercase, with `-` characters replaced by `_`), the value being the header values.
|
||||
note: >
|
||||
Instrumentations SHOULD require an explicit configuration of which headers are to be captured.
|
||||
Including all response headers can be a security risk - explicit configuration helps avoid leaking sensitive information.
|
||||
|
||||
Users MAY explicitly configure instrumentations to capture them even though it is not recommended.
|
||||
|
||||
The attribute value MUST consist of either multiple header values as an array of strings
|
||||
or a single-item array containing a possibly comma-concatenated string, depending on the way
|
||||
the HTTP library provides access to headers.
|
||||
examples: ['http.response.header.content_type=["application/json"]', 'http.response.header.my_custom_header=["abc", "def"]']
|
||||
- ref: http.request.method
|
||||
sampling_relevant: true
|
||||
requirement_level: required
|
||||
- ref: network.transport
|
||||
requirement_level:
|
||||
conditionally_required: If not default (`tcp` for `HTTP/1.1` and `HTTP/2`, `udp` for `HTTP/3`).
|
||||
|
|
@ -68,23 +26,14 @@ groups:
|
|||
- ref: user_agent.original
|
||||
|
||||
- id: trace.http.client
|
||||
prefix: http
|
||||
type: span
|
||||
extends: attributes.http.client
|
||||
span_kind: client
|
||||
brief: 'Semantic Convention for HTTP Client'
|
||||
attributes:
|
||||
- id: resend_count
|
||||
type: int
|
||||
brief: >
|
||||
The ordinal number of request resending attempt (for any reason, including redirects).
|
||||
note: >
|
||||
The resend count SHOULD be updated each time an HTTP request gets resent by the client, regardless of what
|
||||
was the cause of the resending (e.g. redirection, authorization failure, 503 Server Unavailable, network issues,
|
||||
or any other).
|
||||
- ref: http.resend_count
|
||||
requirement_level:
|
||||
recommended: if and only if request was retried.
|
||||
examples: 3
|
||||
- ref: server.address
|
||||
sampling_relevant: true
|
||||
requirement_level: required
|
||||
|
|
@ -117,7 +66,6 @@ groups:
|
|||
|
||||
|
||||
- id: trace.http.server
|
||||
prefix: http
|
||||
type: span
|
||||
extends: attributes.http.server
|
||||
span_kind: server
|
||||
|
|
|
|||
Loading…
Reference in New Issue