Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Blog post: HTTP semantic conventions declared stable #3472

Merged
merged 45 commits into from
Nov 4, 2023
Merged
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
21b9194
HTTP semconv stability
trask Nov 2, 2023
fd78f77
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 2, 2023
e5eb050
Apply suggestions from code review
trask Nov 2, 2023
0b4e4d8
No level-1 headings
trask Nov 2, 2023
257ecc9
link
trask Nov 2, 2023
4ebe9bf
words
trask Nov 3, 2023
a11fd66
levels
trask Nov 3, 2023
29fe8fc
simpler
trask Nov 3, 2023
e3162eb
Format + refcache
chalin Nov 3, 2023
1bc4322
Fix dict
chalin Nov 3, 2023
b18d6d1
@chalin's suggestions ❤️
trask Nov 3, 2023
d432d30
Fix formatting
chalin Nov 3, 2023
8e8ce21
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
17807f4
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
feb7d00
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
5dde1eb
Migration plan
trask Nov 3, 2023
4b21e2e
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
d2c47f6
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
df95c5b
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
9a9d2aa
redo migration plan section
trask Nov 3, 2023
e12452b
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
bf75b8e
word
trask Nov 3, 2023
9ae7882
Explain client.* and server.* advantage
trask Nov 3, 2023
b0947bf
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
15ff9ca
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
88a36c3
Apply suggestions from code review
trask Nov 3, 2023
380c866
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
54aad43
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
e3ab8e9
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
9d7f326
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
f5214c2
Apply suggestions from code review
trask Nov 3, 2023
26f8ad5
arrows
trask Nov 3, 2023
5f00488
Apply suggestions from code review
trask Nov 3, 2023
95119a5
clarify
trask Nov 3, 2023
b44e136
caps
trask Nov 3, 2023
94af295
On ...
trask Nov 3, 2023
0dc9dee
npm run fix:format
trask Nov 3, 2023
874f9d9
Merge branch 'main' into http-semconv-stability
trask Nov 3, 2023
dee2158
fix
trask Nov 3, 2023
94564f5
Update content/en/blog/2023/http-conventions-declared-stable.md
trask Nov 3, 2023
4e985bf
Merge branch 'main' into http-semconv-stability
trask Nov 3, 2023
a387f16
Merge branch 'main' into http-semconv-stability
mhausenblas Nov 4, 2023
01746f9
Merge branch 'main' into http-semconv-stability
cartermp Nov 4, 2023
00627e7
Update http-conventions-declared-stable.md
cartermp Nov 4, 2023
b5bcd19
Merge branch 'main' into http-semconv-stability
cartermp Nov 4, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
272 changes: 272 additions & 0 deletions content/en/blog/2023/http-conventions-declared-stable.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,272 @@
---
title: HTTP semantic conventions declared stable
linkTitle: HTTP semconv are stable
date: 2023-11-03
cartermp marked this conversation as resolved.
Show resolved Hide resolved
author: '[Trask Stalnaker](https://github.com/trask) (Microsoft)'
cSpell:ignore: chalin Liudmila Molkova
---

Early this year, we launched an effort to stabilize HTTP semantic conventions.
Today, we proudly announce that the HTTP semantic conventions are the _first_
OpenTelemetry semantic conventions to be declared
**[stable](/docs/specs/otel/document-status/)**! This inaugural stable
[v1.23.0](https://github.com/open-telemetry/semantic-conventions/releases/tag/v1.23.0)
release marks a substantial advancement from earlier versions, featuring:

mhausenblas marked this conversation as resolved.
Show resolved Hide resolved
- Enhancements resulting from
[convergence with the Elastic Common Schema](/blog/2023/ecs-otel-semconv-convergence/),
such as:
- The `url.*` namespace, which can be reused in the future by non-HTTP
semantic conventions
- Replacing the `net.peer.*` and `net.host.*` namespaces with `client.*` and
`server.*`, which
- Works better for logs, where there's no span kind to indicate which side
is peer and which side is host
- Simplifies correlation across client and server telemetry (e.g. since you
can join directly on `server.address` instead of joining where
`net.peer.addr` == `net.host.addr`)
- Provides a clean separation from the `network.*` namespace which is now
only for low-level network attributes
- More consistency around using the `http.request.*` and `http.response.*`
namespaces
- Improved consistency with Prometheus through standardization on seconds for
metric units.
- Streamlined attribute capture by omitting less useful attributes, reducing
telemetry capture, processing, and storage costs.
- Clarified the definition of default values, eliminating ambiguities when
attributes are absent.
- HTTP metrics are no longer vulnerable to cardinality explosion
- `http.request.method` is limited to a (configurable) set of known methods
- `server.address` and `server.port`, which are influenced by the `Host`
header, are now Opt-In on HTTP metrics

## Migration plan

Due to the significant number of modifications and the extensive user base
affected by them, we require existing HTTP instrumentations published by
OpenTelemetry to implement a migration plan that will assist users in
transitioning to the stable HTTP semantic conventions. We plan to use a similar
migration plan when stabilizing other semantic conventions.
trask marked this conversation as resolved.
Show resolved Hide resolved

Specifically, when existing HTTP instrumentations published by OpenTelemetry are
updated to the stable HTTP semantic conventions, they:

- Need to introduce an environment variable `OTEL_SEMCONV_STABILITY_OPT_IN` in
their existing major version, which accepts:
- `http` - emit the stable HTTP and networking conventions, and stop emitting
the old HTTP and networking conventions that the instrumentation emitted
previously.
- `http/dup` - emit both the old and the stable HTTP and networking
conventions, allowing for a phased rollout of the stable semantic
conventions.
- The default behavior (in the absence of one of these values) is to continue
emitting whatever version of the old HTTP and networking conventions the
instrumentation was emitting previously.
- Need to maintain (security patching at a minimum) their existing major version
for at least six months after it starts emitting both sets of conventions.
- May drop the environment variable in their next major version and emit only
the stable HTTP and networking conventions.

## Summary of changes

In this section, we summarize the changes made to the HTTP semantic conventions
from
[v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/trace/semantic_conventions/http.md)
to
[v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/).

### Common attributes across HTTP client and server spans

<!-- prettier-ignore-start -->
| Change | Comments |
| --- | --- |
| `http.method` &rarr; `http.request.method` | Now captures only 9 common HTTP methods by default (configurable) plus `_OTHER` |
| `http.status_code` &rarr; `http.response.status_code` | |
| `http.request.header.<key>` | &bullet; Dash (`"-"`) to underscore (`"_"`) normalization in `<key>` has been removed<br>&bullet; On HTTP server spans: now must be provided to sampler |
| `http.response.header.<key>` | Dash (`"-"`) to underscore (`"_"`) normalization in `<key>` has been removed |
| `http.request_content_length` &rarr; `http.request.body.size` | &bullet; Recommended &rarr; Opt-In<br>&bullet; _Not marked stable yet_ |
| `http.response_content_length` &rarr; `http.response.body.size` | &bullet; Recommended &rarr; Opt-In<br>&bullet; _Not marked stable yet_ |
| `user_agent.original` | &bullet; On HTTP client spans: Recommended &rarr; Opt-In<br>&bullet; On HTTP server spans: now must be provided to sampler<br>&bullet; See note if [migrating from <= v1.18.0](#migrating-from--v1180) |
| `net.protocol.name` &rarr; `network.protocol.name` | Recommended &rarr; Conditionally required if not `http` and `network.protocol.version` is set |
| `net.protocol.version` &rarr; `network.protocol.version` | &bullet; Examples fixed: `2.0` &rarr; `2` and `3.0` &rarr; `3`<br>&bullet; See note if [migrating from <= v1.19.0](#migrating-from--v1190) |
| `net.sock.family` | Removed |
| `net.sock.peer.addr` &rarr; `network.peer.address` | On HTTP server spans: if `http.client_ip` was unknown, then also `net.sock.peer.addr` &rarr; `client.address`; `client.address` must be provided to sampler |
| `net.sock.peer.port` &rarr; `network.peer.port` | Now captured even if same as `server.port` |
| `net.sock.peer.name` | Removed |
| New: `http.request.method_original` | Only captured when `http.request.method` is `_OTHER` |
| New: `error.type` | |
{.td-initial .table .table-responsive}
<!-- prettier-ignore-end -->

References:

- [Common attributes v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/trace/semantic_conventions/http.md#common-attributes)
- [Common attributes v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/http-spans.md#common-attributes)

### HTTP client span attributes

<!-- TODO(@chalin): I'll move this embedded style elsewhere in a followup PR -->
<style>
.ot-table-first-row-50 td:first-child { width: 50%; }
.ot-table-first-row-60 td:first-child { width: 60%; }
</style>

<!-- prettier-ignore-start -->
| Change | Comments |
| --- | --- |
| `http.url` &rarr; `url.full` | |
| `http.resend_count` &rarr; `http.request.resend_count` | |
| `net.peer.name` &rarr; `server.address` | |
| `net.peer.port` &rarr; `server.port` | Now captured even when same as default port for scheme |
{.td-initial .table .table-responsive .ot-table-first-row-60}
<!-- prettier-ignore-end -->

References:

- [HTTP client span attributes v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/trace/semantic_conventions/http.md#http-client)
- [HTTP client span attributes v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/http-spans.md#http-client)

### HTTP server span attributes

<!-- prettier-ignore-start -->
| Change | Comments |
| --- | --- |
| `http.route` | No change |
| `http.target` &rarr; `url.path` and `url.query` | Split into two separate attributes |
| `http.scheme` &rarr; `url.scheme` | Now factors in [X-Forwarded-Proto][], [Forwarded#proto][] headers |
| `http.client_ip` &rarr; `client.address` | If `http.client_ip` was unknown (i.e., no [X-Forwarded-For][], [Forwarded#for][] headers), then `net.sock.peer.addr` &rarr; `client.address`; now must be provided to sampler |
| `net.host.name` &rarr; `server.address` | Now based only on [Host][Host header], [:authority][HTTP/2 authority], [X-Forwarded-Host][], [Forwarded#host][] headers |
| `net.host.port` &rarr; `server.port` | Now based only on [Host][Host header], [:authority][HTTP/2 authority], [X-Forwarded-Host][X-Forwarded-Host], [Forwarded#host][] headers |
{.td-initial .table .table-responsive .ot-table-first-row-50}
<!-- prettier-ignore-end -->

References:

- [HTTP server span attributes v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/trace/semantic_conventions/http.md#http-server)
- [HTTP server span attributes v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/http-spans.md#http-server)

### HTTP client and server span names

The `{http.method}` portion of span names is replace by `HTTP` when
`{http.method}` is `_OTHER`.

See note if [migrating from `<= v1.17.0`](#migrating-from--v1170).

References:

- [HTTP client and server span names v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/trace/semantic_conventions/http.md#name)
- [HTTP client and server span names v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/http-spans.md#name)

### HTTP client duration metric

Metric changes:

- **Name**: `http.client.duration` &rarr; `http.client.request.duration`
- **Unit**: `ms` &rarr; `s`
- **Description**: `Measures the duration of inbound HTTP requests.` &rarr;
`Duration of HTTP server requests.`
- **Histogram buckets**: boundaries updated to reflect change from milliseconds
to seconds, and zero bucket boundary removed
- **Attributes**: see table below

<!-- prettier-ignore-start -->
| Attribute change | Comments |
| --- | --- |
| `http.method` &rarr; `http.request.method` | Now captures only 9 common HTTP methods by default plus `_OTHER` |
| `http.status_code` &rarr; `http.response.status_code` | |
| `net.peer.name` &rarr; `server.address` | |
| `net.peer.port` &rarr; `server.port` | Now captured even when same as default port for scheme |
| `net.sock.peer.addr` | Removed |
| `net.protocol.name` &rarr; `network.protocol.name` | Recommended &rarr; Conditionally required if not `http` and `network.protocol.version` is set |
| `net.protocol.version` &rarr; `network.protocol.version` | Examples fixed: `2.0` &rarr; `2` and `3.0` &rarr; `3`; see note if [migrating from `<= v1.19.0`](#migrating-from--v1190) |
| New: `error.type` | |
{.td-initial .table .table-responsive}
<!-- prettier-ignore-end -->

References:

- [Metric `http.client.duration` v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/metrics/semantic_conventions/http-metrics.md#metric-httpclientduration)
- [Metric `http.client.request.duration` v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.23.0/docs/http/http-metrics.md#metric-httpclientrequestduration)

### HTTP server duration metric

Metric changes:

- **Name**: `http.server.duration` &rarr; `http.server.request.duration`
- **Unit**: `ms` &rarr; `s`
- **Description**: `Measures the duration of inbound HTTP requests.` &rarr;
`Duration of HTTP server requests.`
- **Histogram buckets**: boundaries updated to reflect change from milliseconds
to seconds, and zero bucket boundary removed
- **Attributes**: see table below

<!-- prettier-ignore-start -->
| Attribute change | Comments |
| --- | --- |
| `http.route` | No change |
| `http.method` → `http.request.method` | Now captures only 9 common HTTP methods by default plus `_OTHER` |
| `http.status_code` → `http.response.status_code` | |
| `http.scheme` → `url.scheme` | Now factors in [`X-Forwarded-Proto` span][X-Forwarded-Proto], [`Forwarded#proto` span][Forwarded#proto] headers |
| `net.protocol.name` → `network.protocol.name` | Recommended → Conditionally required if not `http` and `network.protocol.version` is set |
| `net.protocol.version` → `network.protocol.version` | Examples fixed: `2.0` → `2` and `3.0` → `3`; see note if [migrating from `<= v1.19.0`](#migrating-from--v1190) |
| `net.host.name` → `server.address` | &bullet; Recommended → Opt-In (due to high-cardinality vulnerability since based on HTTP headers)<br>&bullet; Now based only on [`Host` span][Host header], [`:authority` span][HTTP/2 authority], [`X-Forwarded-Host` span][X-Forwarded-Host], [`Forwarded#host` span][Forwarded#host] headers |
| `net.host.port` → `server.port` | &bullet; Recommended → Opt-In (due to high-cardinality vulnerability since based on HTTP headers)<br>&bullet; Now based only on [`Host` span][Host header], [`:authority` span][HTTP/2 authority], [`X-Forwarded-Host` span][X-Forwarded-Host], [`Forwarded#host` span][Forwarded#host] headers |
| New: `error.type` | |
{.td-initial .table .table-responsive .ot-table-first-row-50}
<!-- prettier-ignore-end -->

trask marked this conversation as resolved.
Show resolved Hide resolved
References:

- [Metric `http.server.duration` v1.20.0](https://github.com/open-telemetry/opentelemetry-specification/blob/v1.20.0/specification/metrics/semantic_conventions/http-metrics.md#metric-httpserverduration)
- [Metric `http.server.request.duration` v1.23.0 (stable)](https://github.com/open-telemetry/semantic-conventions/blob/v1.22.0/docs/http/http-metrics.md#metric-httpserverrequestduration)

## Migrating from a version earlier than v1.20.0?

### Migrating from `<= v1.19.0`

- `http.flavor` &rarr; `network.protocol.version`
- Examples fixed: `2.0` &rarr; `2` and `3.0` &rarr; `3`

### Migrating from `<= v1.18.0`

- `http.user_agent` &rarr; `user_agent.original`

### Migrating from `<= v1.17.0`

#### HTTP server span name

- When `http.route` is available:<br> `{http.route}` &rarr;
`{summary} {http.route}`
- When `http.route` is not available:<br> `HTTP {http.method}` &rarr;
`{summary}`

Where `{summary}` is `{http.method}`, unless `{http.method}` is `_OTHER`, in
which case `{summary}` is `HTTP`.

#### HTTP client span name

- `HTTP {http.method}` &rarr; `{summary}`

Where `{summary}` is `{http.method}`, unless `{http.method}` is `_OTHER`, in
which case `{summary}` is `HTTP`.

[Host header]: https://tools.ietf.org/html/rfc7230#section-5.4
[HTTP/2 authority]: https://tools.ietf.org/html/rfc9113#section-8.3.1
[Forwarded#for]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#for
[Forwarded#proto]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#proto
[Forwarded#host]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#host
[X-Forwarded-For]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-For
[X-Forwarded-Proto]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-Proto
[X-Forwarded-Host]:
https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-Host

## Community Kudos

This was a massive community effort: thanks to all who got involved! A special
thanks to [Liudmila Molkova](https://github.com/lmolkova) for sharing her HTTP
domain expertise, which helped drive this effort every step of the way.
36 changes: 36 additions & 0 deletions static/refcache.json
Original file line number Diff line number Diff line change
Expand Up @@ -619,6 +619,30 @@
"StatusCode": 206,
"LastSeen": "2023-06-29T18:51:23.515285-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#for": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:16.900109-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#host": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:48.340922-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/Forwarded#proto": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:27.385988-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-For": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:11.582225-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-Host": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:43.193675-04:00"
},
"https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Forwarded-Proto": {
"StatusCode": 206,
"LastSeen": "2023-11-03T03:04:22.148405-04:00"
},
"https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS": {
"StatusCode": 206,
"LastSeen": "2023-06-29T15:53:59.660121-04:00"
Expand Down Expand Up @@ -2263,6 +2287,10 @@
"StatusCode": 200,
"LastSeen": "2023-06-30T08:32:10.766549-04:00"
},
"https://github.com/lmolkova": {
"StatusCode": 200,
"LastSeen": "2023-11-03T03:04:54.119611-04:00"
},
"https://github.com/mahboubii/grpcmetrics": {
"StatusCode": 200,
"LastSeen": "2023-06-30T09:15:29.922451-04:00"
Expand Down Expand Up @@ -3487,6 +3515,10 @@
"StatusCode": 200,
"LastSeen": "2023-11-01T21:52:00.884558-04:00"
},
"https://github.com/open-telemetry/semantic-conventions/releases/tag/v1.23.0": {
"StatusCode": 200,
"LastSeen": "2023-11-03T20:22:42.689401141Z"
},
"https://github.com/opentracing": {
"StatusCode": 200,
"LastSeen": "2023-06-30T08:40:39.909083-04:00"
Expand Down Expand Up @@ -5331,6 +5363,10 @@
"StatusCode": 200,
"LastSeen": "2023-06-29T18:42:20.913106-04:00"
},
"https://tools.ietf.org/html/rfc9113#section-8.3.1": {
"StatusCode": 200,
"LastSeen": "2023-11-03T03:04:37.939785-04:00"
},
"https://tracetest.io/": {
"StatusCode": 206,
"LastSeen": "2023-08-14T12:06:16.100357-03:00"
Expand Down