Skip to content

Commit

Permalink
Documentation for new telemetry configuration.
Browse files Browse the repository at this point in the history
Many of the features are not implemented yet and will be enabled over time.
Part of #3226
  • Loading branch information
bryn committed Nov 2, 2023
1 parent 12a4697 commit 791ac79
Show file tree
Hide file tree
Showing 23 changed files with 2,390 additions and 0 deletions.
8 changes: 8 additions & 0 deletions apollo-router/src/plugins/telemetry/config_new/attributes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,14 @@ pub(crate) enum Query {
#[derive(Deserialize, JsonSchema, Clone, Debug)]
#[cfg_attr(test, derive(Serialize))]
#[serde(deny_unknown_fields, rename_all = "snake_case")]
pub(crate) enum Query {
/// The raw query kind.
String,
}

#[allow(dead_code)]
#[derive(Deserialize, JsonSchema, Clone, Debug)]
#[serde(deny_unknown_fields, rename_all = "snake_case")]
pub(crate) enum OperationKind {
/// The raw operation kind.
String,
Expand Down
98 changes: 98 additions & 0 deletions docs/source/configuration/telemetry_next/conditions.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
---
title: Selectors
---

## Conditions

Conditions are used to define when an [instruments](instruments.mdx) or [events](events.mdx) should happen.

Here is an example of a condition on a custom instrument:

```yaml title="router.yaml"
telemetry:
instruments:
router:
my.instrument:
# ...
# This instrument will only be mutated if the condition evaluates to true
condition:
all:
- any:
- eq:
- "val"
- request_header: x-req-header
- eq:
- "foo"
- response_header: x-resp-header
```
### Configuration
A condition is one of `all`, `any`, `not` or `eq`. With these building blocks you can create complex conditions.

#### `all`
`all` is a list of conditions that must all be true for the condition to be true.

For example, the following condition checks the values of `x-req-header1` and `x-req-header2` all of which must be true:
```yaml
all:
- eq:
- "val1"
- request_header: x-req-header1
- eq:
- "val2"
- request_header: x-req-header2
```

#### `any`
`any` is a list of conditions of which at least one must be true for the condition to be true.

For example, the following condition checks the values of `x-req-header1` and `x-req-header2` one of which must be true:
```yaml
any:
- eq:
- "val2"
- request_header: x-req-header1
- eq:
- "val2"
- request_header: x-req-header2
```

#### `eq`
`eq` is an equality test between [selectors](selectors.mdx) or values.

For example, the following condition checks the value of `x-req-header` is equal to `val`:
```yaml
eq:
- "val"
- request_header: x-req-header
```

You may use selectors on both sides of the equality test:
```yaml
eq:
- request_header: x-req-header1
- request_header: x-req-header2
```

Values may be of types `string`, `number` or `boolean`.

#### `not`
`not` is a negation of the nested condition.

For example, the following condition checks the value of `x-req-header` is not equal to `val1`:
```yaml
not:
eq:
- "val1"
- request_header: x-req-header2
```

### Configuration reference

| Selector | Description |
|----------|----------------------------------------------------------|
| `all` | A list of conditions that must all be true. |
| `any` | A list of conditions of which at least one must be true. |
| `eq` | An equality test between selectors or values. |
| `not` | The nested condition must not be true. |

189 changes: 189 additions & 0 deletions docs/source/configuration/telemetry_next/events.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,189 @@
---
title: Events
---

## Events

Events are used to signal that something happened in the Router pipeline. They are output to both logs and traces.

The Router has three major pipeline stages:
* router - The incoming request, before it is parsed, bytes focused.
* supergraph - The request after it has been parsed and before it is sent to the subgraph, graphql focused.
* subgraph - The request after it has been sent to the subgraph, graphql focused.

Each within each stage you may configure custom events that will be triggered via `router.yaml`.

### Configuration

```yaml title="router.yaml"
telemetry:
events:
router:
# Standard events
request: info
response: info
error: info

# Custom events
my.event:
message: "my event message"
level: info
on: request
attributes:
http.response.body.size: false
# Only log when the x-log-request header is `log`
condition:
eq:
- "log"
- request_header: "x-log-request"

supergraph:
attributes:
# ...
subgraph:
attributes:
# ...

```

### Configuration

#### `router`|`supergraph`|`subgraph`

The `router`, `supergraph` and `subgraph` sections are used to define custom event configuration for the `router`, `supergraph` and `subgraph` stages respectively.

```yaml title="router.yaml"
telemetry:
events:
router:
# ...
supergraph:
# ...
subgraph:
# ...
```

Each stage has a set of standard events that can be configured:
* `request` - The request has been received.
* `response` - The response has been sent.
* `error` - An error has occurred.

To configure these events, set the level to `trace`, `info`, `warn`, `error` or `off` (default).

You can enable these via router.yaml:
```yaml title="router.yaml"
telemetry:
events:
router:
request: off (default)
response: off (default)
error: error (default)
# ...
```
Note that error only applies to pipeline errors, and not graphql errors.


In addition, for each stage you can configure custom events.

```yaml title="router.yaml"
telemetry:
events:
router:
# Custom events
my.event: # This key will automatically be added as a 'type' attribute of the event
# Custom event configuration
```

#### `message`

Each custom event must have a message. This is a fixed value, and custom attributes should be used to add additional information.

```yaml title="desc.router.yaml"
telemetry:
events:
router:
acme.event:
message: "my event message"
# ...
```

#### `on`

Each custom event event must indicate when it should be triggered. This can be `request`, `response` or `error`.

```yaml title="desc.router.yaml"
telemetry:
events:
router:
acme.event:
on: request # request, response, error
# ...
```

Note that error only applies to pipeline errors, and not graphql errors.

#### `level`

Custom events have a level, `trace`, `info`, `warn` or `error`. The level determines the severity of the event.

To set the level:
```yaml title="desc.router.yaml"
telemetry:
events:
router:
acme.event:
level: info # trace, info, warn, error
# ...
```

#### `condition`

Custom events can be configured to emit under certain conditions. For example, only if the response status code is 200.

To do this use a condition:
```yaml title="desc.router.yaml"
telemetry:
events:
router:
acme.event:
# ...
condition:
eq:
- 200
- response_header: Status
```
#### `attributes`

Custom events may have attributes attached to them from the Router pipeline. These attributes are used to filter and group spans in your APM.

Attributes may be drawn from [standard attributes](standard-attributes.mdx) or [selectors](selectors.mdx).
The attributes available depend on the stage of the pipeline.

```yaml title="desc.router.yaml"
telemetry:
events:
router:
my.event:
# ...
attributes:
# Standard attributes
http.response.status_code: true
# Custom attributes
"my_attribute":
response_header: "x-my-header"
```

### Configuration reference
| Option | Values | Default | Description |
|--------------------|------------------------------------------------------------------------------|---------|-------------------------------------------------------------|
| `<attribute-name>` | | | The name of the custom attribute. |
| `attributes` | [standard attributes](standard-attributes.mdx) or [selectors](selectors.mdx) | | The attributes of the custom log event. |
| `condition` | [conditions](conditions.mdx) | | The condition that must be met for the event to be emitted. |
| `error` | `trace`\|`info`\|`warn`\|`error`\| `off` | `off` | The level of the error log event. |
| `level` | `trace`\|`info`\|`warn`\|`error`\| `off` | `off` | The level of the custom log event. |
| `message` | | | The message of the custom log event. |
| `on` | `request`\|`response`\|`error` | | When to trigger the event. |
| `request` | `trace`\|`info`\|`warn`\|`error`\| `off` | `off` | The level of the request log event. |
| `response` | `trace`\|`info`\|`warn`\|`error`\| `off` | `off` | The level of the response log event. |

Loading

0 comments on commit 791ac79

Please sign in to comment.