- Stage: 3 (finished)
- Date: 2021-06-23
This RFC supersedes issue #841 which implies breaking changes therefore the RFC Process is indicated.
The request is to consolidate log.original
and event.original
by removing log.original
, since these are almost equivalent in nature. (One) justification for preserving event.original
is that not all events are logs. Once log.original
is removed, event.original
will be the sole field intended to capture the original untouched event.
Field Set | Field(s) |
---|---|
log |
log.original |
event |
event.original |
-
The internal description of the field
log.original
inlog
should be amended by addition of a notice of deprecation and subsequently removal if/when Deprecation progresses to Removal -
The internal description of the field
event.original
inevent
should be updated to reflect the revised scope -
The extended description of
log.original
in theLog Fields documentation
should be amended by addition of a notice of deprecation and subsequently removal if/when Deprecation progresses to Removal -
The extended description of
event.original
in theEvent Fields documentation
should be amended to clarify the absorption oflog.original
The following examples are taken verbatim from the existing field definitions and are included for completeness.
These are the raw texts of entire events, for example a log message. They
differ from the extracted message
field in that no processing has been
applied and the field is not indexed by default. The field can still be
retrieved from _source
and is well-suited to demonstration of log integrity
or in a re-index pipeline.
Any or all incoming log or event messages when the original value of the event needs to be preserved.
{"event.original": "Sep 19 08:26:10 host CEF:0|Security|
threatmanager|1.0|100|
worm successfully stopped|10|src=10.0.0.1
dst=2.1.2.2spt=1232"}
{"event.original": "Sep 19 08:26:10 localhost My log"}
{
"event": {
"original": "{\"Node\":\"compute01-hc-xx-local-abcdefgh-com\",\"CheckID\":\"_nomad-check-2724899cc463354bb6336c67421b73f36fb966e2\",\"Name\":\"service: \\\"hello-world\\\" check\",\"Status\":\"passing\",\"Notes\":\"\",\"Output\":\"HTTP GET http://10.100.8.99:8080/: 200 OK Output: Hello world! Your request address: 10.100.8.34:37230\\n\\nRuntime env:\\nPATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\\nHOSTNAME=7c9b09a0258c\\nNOMAD_ALLOC_DIR=/alloc\\nNOMAD_ALLOC_ID=4c62244a-6924-4cb6-60d3-a4c574c58085\\nNOMAD_ALLOC_INDEX=0\\nNOMAD_ALLOC_NAME=hello-world.servers[0]\\nNOMAD_CPU_LIMIT=50\\nNOMAD_DC=xx\\nNOMAD_GROUP_NAME=servers\\nNOMAD_JOB_ID=hello-world\\nNOMAD_JOB_NAME=hello-world\\nNOMAD_MEMORY_LIMIT=32\\nNOMAD_NAMESPACE=default\\nNOMAD_REGION=global\\nNOMAD_SECRETS_DIR=/secrets\\nNOMAD_TASK_DIR=/local\\nNOMAD_TASK_NAME=hello-world\\nHOME=/\\n\",\"ServiceID\":\"_nomad-task-4c62244a-6924-4cb6-60d3-a4c574c58085-group-servers-hello-world-8080\",\"ServiceName\":\"hello-world\",\"ServiceTags\":[\"http\",\"traefik.enable=true\",\"traefik.http.routers.hello-world.entrypoints=https\",\"traefik.http.routers.hello-world.tls.certresolver=le\",\"traefik.http.routers.hello-world.tls.domains[0].main=svc.abcdefgh.com\",\"traefik.http.routers.hello-world.tls.domains[0].sans=*.svc.abcdefgh.com\"],\"Type\":\"http\",\"Definition\":{},\"CreateIndex\":4281349\"ModifyIndex\":5749556}"
}
}
Beats modules, Agent integration packages and the Logging UI would be required to migrate if this change is adopted as proposed.
The removal of log.original
will be considered a breaking change since the field is being removed from the schema. Possible migration/mitigations for users impacted may include:
-
The
Beats default fields inclusion list
list should be updated by removinglog.original
if/when Deprecation progresses to Removal -
The logs UI
message
column currently displayslog.original
in the absence of amessage
field. It should be updated to useevent.original
as the substitute field. See builtin_rules and associated test. Kibana team is aware and has a PR awaiting review which addresses this. -
The breakdown of usage of this field in Kibana source shows:
- 88 usages in tests
- 22 usages outside of tests, e.g.
js
,ts
,map
files
-
For example, references in the RAC Rule Registry will need to be removed - these have
required: false
so hopefully non-breaking change. -
Multiple tests in Kibana will need to be updated see e.g. Function Test APM Mapping
-
TBD would it be beneficial to alias
log.original
for current users of this field -
TBD if there exist current users of fields with distinct content/meaning in a common index mapping
As a breaking change, this would require timely communication to the Elastic Community.
With respect to internal stakeholders, the following actons have been taken:
-
Reached out the Beats + Integrations teams: Filebeat has already taken action, thanks @P1llus
-
Reached out to Logs UI team:
logs.original
has now been superceed byevent.original
as fallback whenmessage
not available, thanks @weltenwort -
Reached out to RAC: the reference RAC Rule Registry has been acknowledged, thanks @jasonrhodes
The following are the people that consulted on the contents of this RFC.
- @djptek | author
- @ebeahan | sponsor
- @andrewkroh | Beats & Logging UI
- @jasonrhodes | Logging UI & RAC
- @MikePaquette | RAC