Skip to content
This repository has been archived by the owner on Dec 6, 2024. It is now read-only.

Define Log Data model #97

Merged

Conversation

tigrannajaryan
Copy link
Member

@tigrannajaryan tigrannajaryan commented Apr 13, 2020

This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.

@tigrannajaryan
Copy link
Member Author

@open-telemetry/specs-approvers please review. The initial wave of discussion happened in the Google Doc. I believe it is time to move to refinements and eventual approval.

@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from e3be95e to a1c863d Compare April 28, 2020 04:48
@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from a07b657 to 66c2d9e Compare April 28, 2020 22:49
@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from 66c2d9e to 3720df0 Compare April 30, 2020 01:04
@tigrannajaryan
Copy link
Member Author

@open-telemetry/specs-approvers please review.

@roncohen
Copy link

roncohen commented May 1, 2020

thank you for the hard work on this @tigrannajaryan and others. I understand the wish to keep up the momentum and move forward on this. One point that recently came up was whether we need to consider how the data model can be made to encompass not just logs, but also tracing events and metrics or at least how it will interoperate with these. cc'ing @tedsuo because I believe we discussed it in a recent call.

@roncohen
Copy link

roncohen commented May 1, 2020

one of the requirements for this model is that is can be unambiguously mapped to from common models. It doesn't look like we've been through that exercise for the Elastic Common Schema (ECS) and it is not present here. I'm happy to take a swing at it, if that sounds appropriate.

@tigrannajaryan
Copy link
Member Author

one of the requirements for this model is that is can be unambiguously mapped to from common models. It doesn't look like we've been through that exercise for the Elastic Common Schema (ECS) and it is not present here. I'm happy to take a swing at it, if that sounds appropriate.

@roncohen Yes, definitely, please do. Happy to add it to this OTEP or reference it from this OTEP if you post it elsewhere.

@tigrannajaryan
Copy link
Member Author

I'm not sure why they belong in the spec if that's the case. If we want to include example uses such as these vendor specifics then they belong in a different file/location versus in the appendix. It seems like free advertising for commercial solutions which doesn't belong in this forum. If those are to be included then we should open that up to all vendor solutions who want to be included in the specification.

I'll leave up to OpenTelemetry admins to decide if having this is appropriate in an OTEP. I believe examples help clarify the OTEP and should stay.

@jkowall
Copy link

jkowall commented May 22, 2020

I'll leave up to OpenTelemetry admins to decide if having this is appropriate in an OTEP. I believe examples help clarify the OTEP and should stay.

No problem, I'll submit a PR for a logz.io example section to be added in fairness if that's how we're going to proceed. Personally, I do not believe this is the right forum for vendor names to be included.

Copy link

@jkowall jkowall left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Approved aside from my objection in having vendor names included. I will add a section for my employer after this is approved as right now only Splunk, Signalfx (also Splunk), Google, Microsoft are referenced examples.

@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from ca19785 to 75bd614 Compare May 22, 2020 19:41
Tigran Najaryan added 7 commits May 22, 2020 15:56
This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.
@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from 75bd614 to 33bcdf0 Compare May 22, 2020 19:56
text/0097-log-data-model.md Outdated Show resolved Hide resolved
Copy link
Member

@reyang reyang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM.

@tigrannajaryan tigrannajaryan force-pushed the feature/tigran/log-data-model branch from 33bcdf0 to 9b721ee Compare May 22, 2020 23:45
@bogdandrutu bogdandrutu merged commit 22990a5 into open-telemetry:master May 22, 2020
@tigrannajaryan tigrannajaryan deleted the feature/tigran/log-data-model branch June 16, 2020 18:02
tigrannajaryan added a commit to open-telemetry/opentelemetry-specification that referenced this pull request Apr 6, 2023
Fixes #597

## Changes

- Add a section for "generic attributes" to the log semconv
- Add an attribute `log_record.id` making use of ULID as discussed in
#597

Some additional notes:
- I kept the PR small, so I left out some other potential attributes,
e.g. something for pre-existing ID (like windows event logs) or for
storing the used logging/eventing system or even something like a
"signature" that might be worth discussing, etc.
- I followed the structure of "generic attributes" from the spans
semconv
- I took some of the existing wording from #597 &
open-telemetry/oteps#97 (comment) to
describe the field

---------

Signed-off-by: svrnm <[email protected]>
Co-authored-by: Joao Grassi <[email protected]>
Co-authored-by: jack-berg <[email protected]>
Co-authored-by: Tigran Najaryan <[email protected]>
jsuereth pushed a commit to jsuereth/otel-semconv-test that referenced this pull request Apr 19, 2023
Fixes #597

## Changes

- Add a section for "generic attributes" to the log semconv
- Add an attribute `log_record.id` making use of ULID as discussed in
#597

Some additional notes:
- I kept the PR small, so I left out some other potential attributes,
e.g. something for pre-existing ID (like windows event logs) or for
storing the used logging/eventing system or even something like a
"signature" that might be worth discussing, etc.
- I followed the structure of "generic attributes" from the spans
semconv
- I took some of the existing wording from #597 &
open-telemetry/oteps#97 (comment) to
describe the field

---------

Signed-off-by: svrnm <[email protected]>
Co-authored-by: Joao Grassi <[email protected]>
Co-authored-by: jack-berg <[email protected]>
Co-authored-by: Tigran Najaryan <[email protected]>
jsuereth pushed a commit to open-telemetry/semantic-conventions that referenced this pull request May 11, 2023
Fixes #597

## Changes

- Add a section for "generic attributes" to the log semconv
- Add an attribute `log_record.id` making use of ULID as discussed in
#597

Some additional notes:
- I kept the PR small, so I left out some other potential attributes,
e.g. something for pre-existing ID (like windows event logs) or for
storing the used logging/eventing system or even something like a
"signature" that might be worth discussing, etc.
- I followed the structure of "generic attributes" from the spans
semconv
- I took some of the existing wording from #597 &
open-telemetry/oteps#97 (comment) to
describe the field

---------

Signed-off-by: svrnm <[email protected]>
Co-authored-by: Joao Grassi <[email protected]>
Co-authored-by: jack-berg <[email protected]>
Co-authored-by: Tigran Najaryan <[email protected]>
carlosalberto pushed a commit to carlosalberto/oteps that referenced this pull request Oct 23, 2024
* Define Log Data model

This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.

* Move content from Google Doc to markdown here

* Address PR comments

* Add Google Cloud Logging mapping

* Address PR comments

* Resolve Open Questions

* Add ECS mapping

* Address PR comments
carlosalberto pushed a commit to carlosalberto/oteps that referenced this pull request Oct 23, 2024
* Define Log Data model

This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.

* Move content from Google Doc to markdown here

* Address PR comments

* Add Google Cloud Logging mapping

* Address PR comments

* Resolve Open Questions

* Add ECS mapping

* Address PR comments
carlosalberto pushed a commit to carlosalberto/oteps that referenced this pull request Oct 30, 2024
* Define Log Data model

This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.

* Move content from Google Doc to markdown here

* Address PR comments

* Add Google Cloud Logging mapping

* Address PR comments

* Resolve Open Questions

* Add ECS mapping

* Address PR comments
carlosalberto pushed a commit to carlosalberto/opentelemetry-specification that referenced this pull request Oct 31, 2024
Fixes open-telemetry#597

## Changes

- Add a section for "generic attributes" to the log semconv
- Add an attribute `log_record.id` making use of ULID as discussed in
open-telemetry#597

Some additional notes:
- I kept the PR small, so I left out some other potential attributes,
e.g. something for pre-existing ID (like windows event logs) or for
storing the used logging/eventing system or even something like a
"signature" that might be worth discussing, etc.
- I followed the structure of "generic attributes" from the spans
semconv
- I took some of the existing wording from open-telemetry#597 &
open-telemetry/oteps#97 (comment) to
describe the field

---------

Signed-off-by: svrnm <[email protected]>
Co-authored-by: Joao Grassi <[email protected]>
Co-authored-by: jack-berg <[email protected]>
Co-authored-by: Tigran Najaryan <[email protected]>
carlosalberto pushed a commit to open-telemetry/opentelemetry-specification that referenced this pull request Nov 8, 2024
* Define Log Data model

This is a proposal of a data model and semantic conventions that allow to
represent logs from various sources: application log files, machine
generated events, system logs, etc.

Existing log formats can be unambiguously mapped to this data model.
Reverse mapping from this data model is also possible to the extent that
the target log format has equivalent capabilities.

The purpose of the data model is to have a common understanding of what a
log record is, what data needs to be recorded, transferred, stored and
interpreted by a logging system.

* Move content from Google Doc to markdown here

* Address PR comments

* Add Google Cloud Logging mapping

* Address PR comments

* Resolve Open Questions

* Add ECS mapping

* Address PR comments
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.