forked from open-telemetry/opentelemetry-specification
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Logs] Add semantic conventions for writing exceptions (open-telemetr…
- Loading branch information
1 parent
475b3dd
commit b2c2432
Showing
7 changed files
with
107 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
groups: | ||
- id: exception | ||
prefix: exception | ||
brief: > | ||
This document defines the shared attributes used to | ||
report a single exception associated with a span or log. | ||
attributes: | ||
- id: type | ||
type: string | ||
brief: > | ||
The type of the exception (its fully-qualified class name, if applicable). | ||
The dynamic type of the exception should be preferred over the static type | ||
in languages that support it. | ||
examples: ["java.net.ConnectException", "OSError"] | ||
- id: message | ||
type: string | ||
brief: The exception message. | ||
examples: ["Division by zero", "Can't convert 'int' object to str implicitly"] | ||
- id: stacktrace | ||
type: string | ||
brief: > | ||
A stacktrace as a string in the natural representation for the language runtime. | ||
The representation is to be determined and documented by each language SIG. | ||
examples: 'Exception in thread "main" java.lang.RuntimeException: Test exception\n | ||
at com.example.GenerateTrace.methodB(GenerateTrace.java:13)\n | ||
at com.example.GenerateTrace.methodA(GenerateTrace.java:9)\n | ||
at com.example.GenerateTrace.main(GenerateTrace.java:5)' | ||
|
||
constraints: | ||
- any_of: | ||
- "exception.type" | ||
- "exception.message" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
groups: | ||
- id: log-exception | ||
prefix: exception | ||
brief: > | ||
This document defines attributes for exceptions represented using Log | ||
Records. | ||
attributes: | ||
- ref: exception.type | ||
- ref: exception.message | ||
- ref: exception.stacktrace | ||
|
||
constraints: | ||
- any_of: | ||
- "exception.type" | ||
- "exception.message" |
25 changes: 4 additions & 21 deletions
25
semantic_conventions/trace/exception.yaml → ...ic_conventions/trace/trace-exception.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
# Semantic Conventions for Exceptions | ||
|
||
**Status**: [Experimental](../../document-status.md) | ||
|
||
This document defines semantic conventions for recording exceptions on | ||
[logs](../api.md#emit-logrecord) and [events](../api.md#emit-event) emitted | ||
through the [Logger API](../api.md#logger). | ||
|
||
<!-- toc --> | ||
|
||
- [Recording an Exception](#recording-an-exception) | ||
- [Attributes](#attributes) | ||
* [Stacktrace Representation](#stacktrace-representation) | ||
|
||
<!-- tocstop --> | ||
|
||
## Recording an Exception | ||
|
||
Exceptions SHOULD be recorded as attributes on the | ||
[LogRecord](../api.md#logrecord) passed to the [Logger](../api.md#logger) emit | ||
operations. Exceptions MAY be recorded on "logs" or "events" depending on the | ||
context. | ||
|
||
To encapsulate proper handling of exceptions API authors MAY provide a | ||
constructor, `RecordException` method/extension, or similar helper mechanism on | ||
the `LogRecord` class/structure or wherever it makes the most sense depending on | ||
the language runtime. | ||
|
||
## Attributes | ||
|
||
The table below indicates which attributes should be added to the | ||
[LogRecord](../api.md#logrecord) and their types. | ||
|
||
<!-- semconv log-exception --> | ||
| Attribute | Type | Description | Examples | Requirement Level | | ||
|---|---|---|---|---| | ||
| `exception.message` | string | The exception message. | `Division by zero`; `Can't convert 'int' object to str implicitly` | See below | | ||
| `exception.stacktrace` | string | A stacktrace as a string in the natural representation for the language runtime. The representation is to be determined and documented by each language SIG. | `Exception in thread "main" java.lang.RuntimeException: Test exception\n at com.example.GenerateTrace.methodB(GenerateTrace.java:13)\n at com.example.GenerateTrace.methodA(GenerateTrace.java:9)\n at com.example.GenerateTrace.main(GenerateTrace.java:5)` | Recommended | | ||
| `exception.type` | string | The type of the exception (its fully-qualified class name, if applicable). The dynamic type of the exception should be preferred over the static type in languages that support it. | `java.net.ConnectException`; `OSError` | See below | | ||
|
||
**Additional attribute requirements:** At least one of the following sets of attributes is required: | ||
|
||
* `exception.type` | ||
* `exception.message` | ||
<!-- endsemconv --> | ||
|
||
### Stacktrace Representation | ||
|
||
Same as [Trace Semantic Conventions for Exceptions - Stacktrace | ||
Representation](../../trace/semantic_conventions/exceptions.md#stacktrace-representation). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters